首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > .NET > C# >

HTML的TABLE转DATATABLE,请帮忙看看解决方法

2012-05-28 
HTML的TABLE转DATATABLE,请帮忙看看TD201205010/TDTD20838193/TDTD好好商城/TDTD12-05-01/

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>&nbsp;</TD>
<TD>&nbsp;</TD>
<TD>0.00</TD>
<TD>广东深圳市盐田区中青路9号</TD>
<TD>1592008</TD>
<TD>彭小姐</TD>
<TD>0.94</TD>
<TD>&nbsp;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>&nbsp;</TD>"             + "<TD>&nbsp;</TD><TD>0.00</TD><TD>广东深圳市盐田区中青路9号</TD><TD>1592008</TD><TD>彭小姐</TD><TD>0.94</TD><TD>&nbsp;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];            } 

热点排行