欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#中DataTable導(dǎo)出為HTML格式的方法

 更新時間:2017年01月05日 16:04:05   作者:Yesi  
在平時的開發(fā)中經(jīng)常會將DataTable數(shù)據(jù)轉(zhuǎn)化到頁面顯示、打印、導(dǎo)出等操作,下面這篇文章主要給大家介紹了C#中DataTable導(dǎo)出為HTML格式的方法,需要的朋友可以參考借鑒,下面來一起看看吧。

前言

在C#中DataTable導(dǎo)出數(shù)據(jù)的時候,我們需要HTML格式的輸出數(shù)據(jù), 這時候就需要使用將DataTable導(dǎo)出為到HTML格式的方法了,以下代碼就可以幫助我們達(dá)到目的。

首先,我們要綁定DataTable和 DataGridView。

一、通過DataTable綁定DataGridView

1. 創(chuàng)建DataTable,添加列

DataTable table = new DataTable(); 
table.Columns.Add("ID", typeof(int)); 
table.Columns.Add("NAME", typeof(string)); 
table.Columns.Add("CITY", typeof(string)); 

2. 再添加行

table.Rows.Add(111, "Devesh", "Ghaziabad"); 
table.Rows.Add(222, "ROLI", "KANPUR"); 
table.Rows.Add(102, "ROLI", "MAINPURI"); 
table.Rows.Add(212, "DEVESH", "KANPUR");

3. 綁定DataGridView

dataGridView1.DataSource=table; 

4. 運行結(jié)果

二、將DataTable 導(dǎo)出為 HTML

我寫了一組代碼來為每個DataTable創(chuàng)建HTML文本。你可以在你的項目中直接引用。

代碼如下:

protected string ExportDatatableToHtml(DataTable dt) 
{ 
StringBuilder strHTMLBuilder = new StringBuilder(); 
strHTMLBuilder.Append("<html >"); 
strHTMLBuilder.Append("<head>"); 
strHTMLBuilder.Append("</head>"); 
strHTMLBuilder.Append("<body>"); 
strHTMLBuilder.Append("<table border='1px' cellpadding='1' cellspacing='1' bgcolor='lightyellow' style='font-family:Garamond; font-size:smaller'>"); 
 
strHTMLBuilder.Append("<tr >"); 
foreach (DataColumn myColumn in dt.Columns) 
{ 
strHTMLBuilder.Append("<td >"); 
strHTMLBuilder.Append(myColumn.ColumnName); 
strHTMLBuilder.Append("</td>"); 
 
} 
strHTMLBuilder.Append("</tr>"); 
 
 
foreach (DataRow myRow in dt.Rows) 
{ 
 
strHTMLBuilder.Append("<tr >"); 
foreach (DataColumn myColumn in dt.Columns) 
{ 
strHTMLBuilder.Append("<td >"); 
strHTMLBuilder.Append(myRow[myColumn.ColumnName].ToString()); 
strHTMLBuilder.Append("</td>"); 
 
} 
strHTMLBuilder.Append("</tr>"); 
} 
 
//Close tags. 
strHTMLBuilder.Append("</table>"); 
strHTMLBuilder.Append("</body>"); 
strHTMLBuilder.Append("</html>"); 
 
string Htmltext = strHTMLBuilder.ToString(); 
 
return Htmltext; 
 
} 

三、代碼理解

我們創(chuàng)建了一個函數(shù),使用DataTable作為參數(shù)。

然后用stringbuilder類創(chuàng)建動態(tài)的HTML文本。

輸出結(jié)果與DataGridView中的行和列數(shù)量相同。

在HTML中創(chuàng)建列。

foreach (DataColumn myColumn in dt.Columns) 
{ 
strHTMLBuilder.Append("<td >"); 
strHTMLBuilder.Append(myColumn.ColumnName); 
strHTMLBuilder.Append("</td>"); 
 
} 

復(fù)制數(shù)據(jù),以下代碼就會在DataTable中創(chuàng)建相同數(shù)量的行,并將數(shù)據(jù)復(fù)制到HTML行中。

foreach (DataRow myRow in dt.Rows) 
{ 
 
strHTMLBuilder.Append("<tr >"); 
foreach (DataColumn myColumn in dt.Columns) 
{ 
strHTMLBuilder.Append("<td >"); 
strHTMLBuilder.Append(myRow[myColumn.ColumnName].ToString()); 
strHTMLBuilder.Append("</td>"); 
 
} 
strHTMLBuilder.Append("</tr>"); 
} 

四、執(zhí)行上面的代碼后得到如下HTML文本

<html >
<head>
</head>
<body>
<table border='1px' cellpadding='1' cellspacing='1' bgcolor='lightyellow' style='font-family:Garamond; font-size:smaller'>
<tr >
<td >ID</td>
<td >NAME</td>
<td >CITY</td>
</tr><tr >
<td >111</td><td >Devesh</td>
<td >Ghaziabad</td></tr>
<tr ><td >222</td><td >ROLI</td>
<td >KANPUR</td></tr><tr >
<td >102</td><td >ROLI</td>
<td >MAINPURI</td></tr><tr >
<td >212</td><td >DEVESH</td>
<td >KANPUR</td></tr></table>
</body>
</html> 

五、創(chuàng)建HTML文件

string HtmlBody = ExportDatatableToHtml(table) 
System.IO.File.WriteAllText(@"c:\abc.HTML", HtmlBody); 

六、運行結(jié)果

總結(jié)

以上就是關(guān)于C#中將DataTable導(dǎo)出為HTML格式的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

相關(guān)文章

最新評論