html的table转datatable
场景:HTML的TABLE转DATATABLE,请帮忙看看解决方法
HTML的TABLE转DATATABLE,请帮忙看看
<TD>201205010</TD>
<TD>20838193</TD>
<TD>好好商城</TD>
<TD>12-05-01</TD>
<TD>12-05-02</TD>
<TD>深圳分发部</TD>
<TD>盐田站</TD>
<TD>配送成功</TD>
<TD>12-05-03</TD>
<TD> </TD>
<TD> </TD>
<TD>0.00</TD>
<TD>广东深圳市盐田区中青路9号</TD>
<TD>1592008</TD>
<TD>彭小姐</TD>
<TD>0.94</TD>
<TD> 1</TD>
<TD>花都仓0</TD>
<TD>曾辉</TD>
上面是HTML代码其中一行代码,请问我如何把<TD>里面的数据转换为DATATABLE或者分列显示到DATAGIRDVIEW?
只需要实现上述其中一种功能即可,谢谢
------解决方案--------------------
思路是这样,先用正则表达式选出所有值, 取出值赋给新建DATATABLE
代码如下:
HTML的TABLE转DATATABLE,请帮忙看看
<TD>201205010</TD>
<TD>20838193</TD>
<TD>好好商城</TD>
<TD>12-05-01</TD>
<TD>12-05-02</TD>
<TD>深圳分发部</TD>
<TD>盐田站</TD>
<TD>配送成功</TD>
<TD>12-05-03</TD>
<TD> </TD>
<TD> </TD>
<TD>0.00</TD>
<TD>广东深圳市盐田区中青路9号</TD>
<TD>1592008</TD>
<TD>彭小姐</TD>
<TD>0.94</TD>
<TD> 1</TD>
<TD>花都仓0</TD>
<TD>曾辉</TD>
上面是HTML代码其中一行代码,请问我如何把<TD>里面的数据转换为DATATABLE或者分列显示到DATAGIRDVIEW?
只需要实现上述其中一种功能即可,谢谢
------解决方案--------------------
思路是这样,先用正则表达式选出所有值, 取出值赋给新建DATATABLE
代码如下:
- C# code
string t = "<TD>201205010</TD><TD>20838193</TD><TD>好好商城</TD><TD>12-05-01</TD><TD>12-05-02</TD><TD>深圳分发部</TD><TD>盐田站</TD><TD>配送成功</TD><TD>12-05-03</TD><TD> </TD>" + "<TD> </TD><TD>0.00</TD><TD>广东深圳市盐田区中青路9号</TD><TD>1592008</TD><TD>彭小姐</TD><TD>0.94</TD><TD> 1</TD><TD>花都仓0</TD><TD>曾辉</TD>"; string pattern=@"<TD>.*?</TD>";//首先是得出每个TD里的值 Regex regex = new Regex(pattern,RegexOptions.IgnoreCase); MatchCollection mc = regex.Matches(t);//mc里放着所有<td> </td>内容 pattern = @"<[^>]*>";//这个正则表达式是取掉<td>,只留下<td>的内容 DataTable dt = new DataTable();//新建DataTable List<string> list=new List<string>();//将所有值存放到这个List中 foreach (Match m in mc) { list.Add(Regex.Replace(m.ToString(), pattern, "")); } for (int i = 0; i < mc.Count; i++) { //为DataTable创建列名,这里是1到19,在dataGridview引用的列名就是1-19,也可以自己取值 //如table有列名,应该将Columns依次赋值列名 dt.Columns.Add(new DataColumn(i.ToString(), typeof(string))); } //这里是一行数据就添加一行,一共多少行数据,可以根据<tr>的数量判断 dt.Rows.Add(dt.NewRow() ); //将值添加到dt.rows中,这样dataGridview就可以使用这个datable作为数据源了 for (int i = 0; i < list.Count; i++) { dt.Rows[0][i] = list[i]; }