c#如何將從txt文檔讀取的數據如此datable中

来源:互联网  责任编辑:小易  时间:2017/5/24 17:46:08
本网有用户碰到这样的问题:c#如何將從txt文檔讀取的數據如此datable中,具体问题如下:

c# datatable

本网根据需求用户需求,为用户寻得以下其他网友提供的解决方法,方法仅供参考,具体如下:

=================1楼=====================

按你的TXT构造一个三列的DataTable,然后split你的数据,分行存进DataTable

=================2楼=====================

引用 1 楼 xiaojie_cp 的回复:
按你的TXT构造一个三列的DataTable,然后split你的数据,分行存进DataTable
還是不太明白,能給點代碼提示下嗎?

=================3楼=====================

首先你这样定义txt数据肯定会出问题
比如
1      光强5       2.00
2      F4-光强063.00       这样你是没法分开数据的

上次就跟你说了txt中的数据每一列都要加一个分隔符,如“,”等
读取txt数据,根据分隔符都到三列数据写入到table中
dataTable绑定数据源,即绑定table

自己动动手,动动脑

=================4楼=====================

参考http://www.cnblogs.com/-lxl/p/5856525.html

=================5楼=====================

csvhelper,设定分割符是\t
或者你自己一行行读取也行,然后split也行

=================6楼=====================

引用 5 楼 starfd 的回复:
csvhelper,设定分割符是\t
或者你自己一行行读取也行,然后split也行

遇到一個問題,是先將txt文檔中的數據讀完嗎,然後用split分割,存入數組中,在填充到dataTable中嗎?
如果這樣的話又該用那種數據類型的數組呢?

=================7楼=====================


 var list= File.ReadAllLines("test.txt");

            DataTable dt=new DataTable();
            dt.Columns.Add("a",typeof(string));
            dt.Columns.Add("b", typeof(string));
            dt.Columns.Add("c", typeof(string));
            foreach (var item in list)
            {
                
                var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);
                DataRow row = dt.NewRow();
               
                row["a"] = values[0];
                row["b"] = values[1];
                row["c"] = values[2];

                dt.Rows.Add(row);
            }




大体就是这样,具体你是什么类型你的dt就写成什么类型,的放的时候转一下就行了.过程中判断下值是否正确,等等

=================8楼=====================

引用 7 楼 royler 的回复:

 var list= File.ReadAllLines("test.txt");

            DataTable dt=new DataTable();
            dt.Columns.Add("a",typeof(string));
            dt.Columns.Add("b", typeof(string));
            dt.Columns.Add("c", typeof(string));
            foreach (var item in list)
            {
                
                var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);
                DataRow row = dt.NewRow();
               
                row["a"] = values[0];
                row["b"] = values[1];
                row["c"] = values[2];

                dt.Rows.Add(row);
            }




大体就是这样,具体你是什么类型你的dt就写成什么类型,的放的时候转一下就行了.过程中判断下值是否正确,等等

確定使用這句不報錯 var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

=================9楼=====================

引用 8 楼 dashanyelang 的回复:
Quote: 引用 7 楼 royler 的回复:


 var list= File.ReadAllLines("test.txt");

            DataTable dt=new DataTable();
            dt.Columns.Add("a",typeof(string));
            dt.Columns.Add("b", typeof(string));
            dt.Columns.Add("c", typeof(string));
            foreach (var item in list)
            {
                
                var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);
                DataRow row = dt.NewRow();
               
                row["a"] = values[0];
                row["b"] = values[1];
                row["c"] = values[2];

                dt.Rows.Add(row);
            }




大体就是这样,具体你是什么类型你的dt就写成什么类型,的放的时候转一下就行了.过程中判断下值是否正确,等等

確定使用這句不報錯 var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

var 不能用的话就这样写

string[] values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

=================10楼=====================

引用 9 楼 ducker3590 的回复:
Quote: 引用 8 楼 dashanyelang 的回复:

Quote: 引用 7 楼 royler 的回复:


 var list= File.ReadAllLines("test.txt");

            DataTable dt=new DataTable();
            dt.Columns.Add("a",typeof(string));
            dt.Columns.Add("b", typeof(string));
            dt.Columns.Add("c", typeof(string));
            foreach (var item in list)
            {
                
                var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);
                DataRow row = dt.NewRow();
               
                row["a"] = values[0];
                row["b"] = values[1];
                row["c"] = values[2];

                dt.Rows.Add(row);
            }




大体就是这样,具体你是什么类型你的dt就写成什么类型,的放的时候转一下就行了.过程中判断下值是否正确,等等

確定使用這句不報錯 var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

var 不能用的话就这样写

string[] values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

不是 var 報錯,是item那裡報錯

=================11楼=====================

引用 10 楼 dashanyelang 的回复:
Quote: 引用 9 楼 ducker3590 的回复:

Quote: 引用 8 楼 dashanyelang 的回复:

Quote: 引用 7 楼 royler 的回复:


 var list= File.ReadAllLines("test.txt");

            DataTable dt=new DataTable();
            dt.Columns.Add("a",typeof(string));
            dt.Columns.Add("b", typeof(string));
            dt.Columns.Add("c", typeof(string));
            foreach (var item in list)
            {
                
                var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);
                DataRow row = dt.NewRow();
               
                row["a"] = values[0];
                row["b"] = values[1];
                row["c"] = values[2];

                dt.Rows.Add(row);
            }




大体就是这样,具体你是什么类型你的dt就写成什么类型,的放的时候转一下就行了.过程中判断下值是否正确,等等

確定使用這句不報錯 var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

var 不能用的话就这样写

string[] values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

不是 var 報錯,是item那裡報錯

你断点看下item的值是什么

=================12楼=====================

引用 10 楼 dashanyelang 的回复:
Quote: 引用 9 楼 ducker3590 的回复:

Quote: 引用 8 楼 dashanyelang 的回复:

Quote: 引用 7 楼 royler 的回复:


 var list= File.ReadAllLines("test.txt");

            DataTable dt=new DataTable();
            dt.Columns.Add("a",typeof(string));
            dt.Columns.Add("b", typeof(string));
            dt.Columns.Add("c", typeof(string));
            foreach (var item in list)
            {
                
                var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);
                DataRow row = dt.NewRow();
               
                row["a"] = values[0];
                row["b"] = values[1];
                row["c"] = values[2];

                dt.Rows.Add(row);
            }




大体就是这样,具体你是什么类型你的dt就写成什么类型,的放的时候转一下就行了.过程中判断下值是否正确,等等

確定使用這句不報錯 var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

var 不能用的话就这样写

string[] values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

不是 var 報錯,是item那裡報錯

=================13楼=====================

引用 12 楼 dashanyelang 的回复:
Quote: 引用 10 楼 dashanyelang 的回复:

Quote: 引用 9 楼 ducker3590 的回复:

Quote: 引用 8 楼 dashanyelang 的回复:

Quote: 引用 7 楼 royler 的回复:


 var list= File.ReadAllLines("test.txt");

            DataTable dt=new DataTable();
            dt.Columns.Add("a",typeof(string));
            dt.Columns.Add("b", typeof(string));
            dt.Columns.Add("c", typeof(string));
            foreach (var item in list)
            {
                
                var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);
                DataRow row = dt.NewRow();
               
                row["a"] = values[0];
                row["b"] = values[1];
                row["c"] = values[2];

                dt.Rows.Add(row);
            }




大体就是这样,具体你是什么类型你的dt就写成什么类型,的放的时候转一下就行了.过程中判断下值是否正确,等等

確定使用這句不報錯 var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

var 不能用的话就这样写

string[] values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

不是 var 報錯,是item那裡報錯

什么错误 我本地测了下没问题

=================14楼=====================

引用 13 楼 ducker3590 的回复:
Quote: 引用 12 楼 dashanyelang 的回复:

Quote: 引用 10 楼 dashanyelang 的回复:

Quote: 引用 9 楼 ducker3590 的回复:

Quote: 引用 8 楼 dashanyelang 的回复:

Quote: 引用 7 楼 royler 的回复:


 var list= File.ReadAllLines("test.txt");

            DataTable dt=new DataTable();
            dt.Columns.Add("a",typeof(string));
            dt.Columns.Add("b", typeof(string));
            dt.Columns.Add("c", typeof(string));
            foreach (var item in list)
            {
                
                var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);
                DataRow row = dt.NewRow();
               
                row["a"] = values[0];
                row["b"] = values[1];
                row["c"] = values[2];

                dt.Rows.Add(row);
            }




大体就是这样,具体你是什么类型你的dt就写成什么类型,的放的时候转一下就行了.过程中判断下值是否正确,等等

確定使用這句不報錯 var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

var 不能用的话就这样写

string[] values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

不是 var 報錯,是item那裡報錯

什么错误 我本地测了下没问题
是這樣

=================15楼=====================

引用 14 楼 dashanyelang 的回复:
Quote: 引用 13 楼 ducker3590 的回复:

Quote: 引用 12 楼 dashanyelang 的回复:

Quote: 引用 10 楼 dashanyelang 的回复:

Quote: 引用 9 楼 ducker3590 的回复:

Quote: 引用 8 楼 dashanyelang 的回复:

Quote: 引用 7 楼 royler 的回复:


 var list= File.ReadAllLines("test.txt");

            DataTable dt=new DataTable();
            dt.Columns.Add("a",typeof(string));
            dt.Columns.Add("b", typeof(string));
            dt.Columns.Add("c", typeof(string));
            foreach (var item in list)
            {
                
                var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);
                DataRow row = dt.NewRow();
               
                row["a"] = values[0];
                row["b"] = values[1];
                row["c"] = values[2];

                dt.Rows.Add(row);
            }




大体就是这样,具体你是什么类型你的dt就写成什么类型,的放的时候转一下就行了.过程中判断下值是否正确,等等

確定使用這句不報錯 var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

var 不能用的话就这样写

string[] values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

不是 var 報錯,是item那裡報錯

什么错误 我本地测了下没问题
是這樣

挡住了

=================16楼=====================

引用 14 楼 dashanyelang 的回复:
Quote: 引用 13 楼 ducker3590 的回复:

Quote: 引用 12 楼 dashanyelang 的回复:

Quote: 引用 10 楼 dashanyelang 的回复:

Quote: 引用 9 楼 ducker3590 的回复:

Quote: 引用 8 楼 dashanyelang 的回复:

Quote: 引用 7 楼 royler 的回复:


 var list= File.ReadAllLines("test.txt");

            DataTable dt=new DataTable();
            dt.Columns.Add("a",typeof(string));
            dt.Columns.Add("b", typeof(string));
            dt.Columns.Add("c", typeof(string));
            foreach (var item in list)
            {
                
                var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);
                DataRow row = dt.NewRow();
               
                row["a"] = values[0];
                row["b"] = values[1];
                row["c"] = values[2];

                dt.Rows.Add(row);
            }




大体就是这样,具体你是什么类型你的dt就写成什么类型,的放的时候转一下就行了.过程中判断下值是否正确,等等

確定使用這句不報錯 var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

var 不能用的话就这样写

string[] values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

不是 var 報錯,是item那裡報錯

什么错误 我本地测了下没问题
是這樣

引用 15 楼 ducker3590 的回复:
Quote: 引用 14 楼 dashanyelang 的回复:

Quote: 引用 13 楼 ducker3590 的回复:

Quote: 引用 12 楼 dashanyelang 的回复:

Quote: 引用 10 楼 dashanyelang 的回复:

Quote: 引用 9 楼 ducker3590 的回复:

Quote: 引用 8 楼 dashanyelang 的回复:

Quote: 引用 7 楼 royler 的回复:


 var list= File.ReadAllLines("test.txt");

            DataTable dt=new DataTable();
            dt.Columns.Add("a",typeof(string));
            dt.Columns.Add("b", typeof(string));
            dt.Columns.Add("c", typeof(string));
            foreach (var item in list)
            {
                
                var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);
                DataRow row = dt.NewRow();
               
                row["a"] = values[0];
                row["b"] = values[1];
                row["c"] = values[2];

                dt.Rows.Add(row);
            }




大体就是这样,具体你是什么类型你的dt就写成什么类型,的放的时候转一下就行了.过程中判断下值是否正确,等等

確定使用這句不報錯 var values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

var 不能用的话就这样写

string[] values= item.Split(new [] {"\t"}, StringSplitOptions.RemoveEmptyEntries);

不是 var 報錯,是item那裡報錯

什么错误 我本地测了下没问题
是這樣

挡住了
是這樣的

=================17楼=====================

这个返回的是一个char数组 Split是string的方法
你用File读取文件应该就可以了


rs.ReadToEnd();

=================18楼=====================

引用 17 楼 ducker3590 的回复:
这个返回的是一个char数组 Split是string的方法
你用File读取文件应该就可以了

rs.ReadToEnd();

謝謝,但是文檔的前2行我是要的,那又該怎麼做?源文檔是這樣的

=================19楼=====================

引用 18 楼 dashanyelang 的回复:
Quote: 引用 17 楼 ducker3590 的回复:

这个返回的是一个char数组 Split是string的方法
你用File读取文件应该就可以了

rs.ReadToEnd();

謝謝,但是文檔的前2行我是要的,那又該怎麼做?源文檔是這樣的

=================20楼=====================

引用 17 楼 ducker3590 的回复:
这个返回的是一个char数组 Split是string的方法
你用File读取文件应该就可以了

rs.ReadToEnd();

謝謝,已經完美的解決了我的問題,那個從第三行開始讀也已經解決了
 var rsList = File.ReadAllLines(@nrs, Encoding.Default).Skip(2);

=================21楼=====================

file有现成的方法去读取文件就没有必要使用 流去读了.流读取出来的还需要转换成string才可以使用.所有你之前的代码分割才会出错.

如果您还有更好的解决方法,请在最下面评论中留下您的解决方法


  • 本文相关:
  • 站长必读,如何真正写好一篇原创文章
  • 互联网之路细嗅蔷薇 资深站长分享掘金之道
  • 企业站的站长的工作重心究竟有哪些
  • 浅析:行业门户网站的一些盈利模式
  • 3000IP的企业网站每天订单不到30个的苦恼
  • 网站想内外兼修?先学习提高网站可用性的6大原则
  • 浅谈网页设计中的简约之美
  • 网页改版实战:日本设计师如何彻底优化旅游网站?
  • 网页改版实战!日本设计师如何彻底优化招聘网站?
  • 2015年值得关注的21个网页设计趋势
  • 免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2015 www.zgxue.com All Rights Reserved