C#读取Excel表中的数据时,为何有些行的字段内容读取不到>?
江湖救急!
rt.
C#读取Excel表中的数据时,为何有些行的字段内容读取不到>?
读取方法示例:
string str = "SELECT * FROM [Sheet1$]";
return this.cmd.ExecuteReader();
String line;
String [] split = null;
DataTable table=new DataTable("auto");
DataRow row=null;
StreamReader sr=new StreamReader("c:/auto.csv",System.Text.Encoding.Default);
//创建与数据源对应的数据列
line = sr.ReadLine();
split=line.Split(',');
foreach(String colname in split){
table.Columns.Add(colname,System.Type.GetType("System.String")); }
//将数据填入数据表
int j=0;
while((line=sr.ReadLine())!=null){
j=0;
row = table.NewRow();
split=line.Split(',');
foreach(String colname in split){
row[j]=colname;
j++;}
table.Rows.Add(row);}
sr.Close();
//显示数据
dataGrid1.DataSource=table.DefaultView;
dataGrid1.DataBind();
你要了解这类访问EXCEL Provider的运行机制.
这种访问方式,provider内部机制回去自动推测判断每列的单元格数据储存类型的.
之所以部分行列的单元格指读取不出来,大部分是因为数据类型的问题.
特别是 同一列有数字,而部分数字储存格式不同,你打开EXCEL就可以看到有绿色的小三角在左上角.
这类读取出来就有可能是空.
[解决办法]
解决了就好~~
[解决办法]
colomtext = workSheet.get_Range(ColNum + "3", Missing.Value).Value2.ToString(); //获取字母列名称