如何用C#将Excel转换成XML文件,希望把一些关键的地方讲得详细些,能让我明白就给分

如题所述

希望这个方法对你有用
///<summary>
///根据excel路径和sheet名称,返回excel的DataSet
///</summary>
public static void GetExcelDataToXml(string path, string tname)
{
/*Office 2007*/
string ace = "Microsoft.ACE.OLEDB.12.0";
/*Office 97 - 2003*/
string jet = "Microsoft.Jet.OLEDB.4.0";
string xl2007 = "Excel 12.0 Xml";
string xl2003 = "Excel 8.0";
string imex = "IMEX=1";
/* csv */
string text = "text";
string fmt = "FMT=Delimited";
string hdr = "Yes";
string conn = "Provider={0};Data Source={1};Extended Properties=\"{2};HDR={3};{4}\";";
string select = string.Format("SELECT * FROM [{0}$]", tname);
//string select = sql;
string ext = Path.GetExtension(path);
OleDbDataAdapter oda;
DataSet ds = newDataSet();
switch (ext.ToLower())
{
case".xlsx":
conn = String.Format(conn, ace, Path.GetFullPath(path), xl2007, hdr, imex);
break;
case".xls":
conn = String.Format(conn, jet, Path.GetFullPath(path), xl2003, hdr, imex);
break;
case".csv":
conn = String.Format(conn, jet, Path.GetDirectoryName(path), text, hdr, fmt);
//sheet = Path.GetFileName(path);
break;
default:
thrownewException("File Not Supported!");
}
OleDbConnection con = newOleDbConnection(conn);
con.Open();
//select = string.Format(select, sql);
oda = newOleDbDataAdapter(select, con);
oda.Fill(ds,"test");
ds.WriteXml("c:/verify.xml");
con.Close();

}
温馨提示:答案为网友推荐,仅供参考
第1个回答  2012-06-18
Excel载入到DataSet
DataSet转到XML文件追问

具体点呢,Excel载入到Dataset,Dataset转成XML文件这两步用到的函数,细节等等

相似回答