public class OutExcelReport
{
/// <summary>
/// 把 DataSet 的數據導成 Excel
/// </summary>
/// <param name="p_dsExport">要導出的 DataSet</param>
/// <param name="p_strFileName">下載時客戶端默認的文件名</param>
/// <param name="p_blnHaveHeaderText">true 標示第一行是列名,默認值爲 true</param>
/// <param name="rrModel">報表統計結果</param>
/// <param name="formType">報表物資類型</param>
public static void DataSetToExcel(DataSet p_dsExport, string p_strFileName, bool p_blnHaveHeaderText, ReportResultModel rrModel, string formType)
{
if (p_dsExport == null)
{
return;
}
string strContext = GenerateWorkSheet(p_dsExport, rrModel, formType);html
DownloadExcelFile(strContext, p_strFileName);
}app
/// <summary>
///
/// </summary>
/// <param name="p_strFileContext"></param>
/// <param name="p_strFileName"></param>
public static void DownloadExcelFile(string p_strFileContext, string p_strFileName)
{
// Appending Headers
if (CommonFunc.IsNullString(p_strFileName))
{
p_strFileName = "Excel.xls";
}ui
if (!p_strFileName.Trim().ToLower().EndsWith(".xls"))
{
p_strFileName += ".xls";
}this
try
{
HttpContext.Current.Response.Clear();
HttpContext.Current.Response.Buffer = true;
p_strFileName = CommonFunc.UrlEncode(p_strFileName);
HttpContext.Current.Response.ContentType = "application/vnd.ms-excel";
HttpContext.Current.Response.AppendHeader("content-disposition", "attachment; filename=" + p_strFileName);
}
catch
{
}excel
//Writeout the Content
HttpContext.Current.Response.Write(p_strFileContext);
try
{
HttpContext.Current.Response.End();
}
catch
{
}
}code
public static string GenerateWorkSheetBottom(string formType, ReportResultModel rrModel)
{
string[] strArraw = new string[8];
switch (formType.ToLower())
{
case "dormrepair": //宿舍維修申請
{
strArraw = new string[] { "統計項", rrModel.Total, "運行中申請單數", rrModel.Running, "已完成申請單數", rrModel.Finished, "", ""};
break;
}
case "managerepair": //辦公維修
{
strArraw = new string[] { "統計項", rrModel.Total, "運行中申請單數", rrModel.Running, "已完成申請單數", rrModel.Finished, "", "" };
break;
}
case "winecollar": //酒水申請
{
strArraw = new string[] { "統計項", rrModel.Total, "運行中申請單數", rrModel.Running, "已完成申請單數", rrModel.Finished, "酒水申請成本彙總", rrModel.AllCost };
break;
}
case "publicactivitysupply"://記念品
{
strArraw = new string[] { "統計項", rrModel.Total, "運行中申請單數", rrModel.Running, "已完成申請單數", rrModel.Finished, "記念品申請成本彙總", rrModel.AllCost };
break;
}
case "adminmaterial": //行政物資
{
strArraw = new string[] { "統計項", rrModel.Total, "運行中申請單數", rrModel.Running, "已完成申請單數", rrModel.Finished, "行政物資成本彙總", rrModel.AllCost };
break;
}
case "consumables": //辦公用品
{
strArraw = new string[] { "統計項", rrModel.Total, "運行中申請單數", rrModel.Running, "已完成申請單數", rrModel.Finished, "辦公文具成本彙總", rrModel.AllCost };
break;
}
case "receptroom": //接待房
{
strArraw = new string[] { "統計項", rrModel.Total, "運行中申請單數", rrModel.Running, "已完成申請單數", rrModel.Finished, "接待房成本彙總", rrModel.AllCost };
break;
}
default:
break;
}orm
StringBuilder strExcelXml = new StringBuilder();
strExcelXml.Append("<Row></Row>\r\n<Row>");
for (int j = 1; j < 9; j++)
{
strExcelXml.Append("<Cell ss:Index=\"" + (j).ToString() + "\"><Data ss:Type=\"String\">");
strExcelXml.Append(CommonFunc.HtmllEncode(strArraw[j - 1]));
strExcelXml.Append("</Data></Cell>\r\n");
}
strExcelXml.Append("</Row>\r\n");
return strExcelXml.ToString();xml
}htm
public static string GenerateWorkSheet(DataSet p_dsExport, ReportResultModel rrModel, string formType)
{
StringBuilder strExcelXml = new StringBuilder();
strExcelXml.Append(ExcelHeader());
strExcelXml.Append(ExcelWorkSheetOptions());string
foreach (DataTable dt in p_dsExport.Tables)
{
strExcelXml.Append("<Worksheet ss:Name=\"" + dt.TableName + "\">");
strExcelXml.Append("<Table>");
#region 用車報表導出的表頭有兩行
//added by dengqian 2013-09-22
if (formType.Equals("manageinfocar") || formType.Equals("industrycar"))
{
strExcelXml.Append(GetHeaderText_tworow(dt));
}
else
{
strExcelXml.Append(GetHeaderText(dt));
}
#endregion
//old: strExcelXml.Append(GetHeaderText(dt));
int intColCount = dt.Columns.Count;
foreach (DataRow dr in dt.Rows)
{
strExcelXml.Append("<Row>\r\n");
for (int j = 0; j < intColCount; j++)
{
strExcelXml.Append("<Cell ss:Index=\"" + (j + 1).ToString() + "\"><Data ss:Type=\"String\">");
strExcelXml.Append(CommonFunc.HtmllEncode(CommonFunc.ObjectToNullStr(dr[j])));
strExcelXml.Append("</Data></Cell>\r\n");
}
strExcelXml.Append("</Row>\r\n");
}
if (rrModel != null)
{
strExcelXml.Append(GenerateWorkSheetBottom(formType, rrModel));
}
strExcelXml.Append("</Table>");
strExcelXml.Append("</Worksheet>");
}
strExcelXml.Append("</Workbook>\r\n");
return strExcelXml.ToString();
}
private static string GetHeaderText(DataTable p_dt)
{
StringBuilder sbRtn = new StringBuilder();
sbRtn.Append("<Row>");
foreach (DataColumn dc in p_dt.Columns)
{
sbRtn.Append("<Cell><Data ss:Type=\"String\">");
sbRtn.Append(dc.ColumnName);
sbRtn.Append("</Data></Cell>\r\n");
}
sbRtn.Append("</Row>");
return sbRtn.ToString();
}
#region 用車報表 兩行表頭的
//added dengqian 201309016
private static string GetHeaderText_tworow(DataTable p_dt)
{
StringBuilder sbRtn = new StringBuilder();
StringBuilder partRtn = new StringBuilder();
sbRtn.Append("<Row>");
partRtn.Append("<Row>");
int rownum = 0;
foreach (DataColumn dc in p_dt.Columns)
{
if (rownum == 0)
{
sbRtn.Append("<Cell rowSpan='2'><Data ss:Type=\"String\">");
sbRtn.Append(dc.ColumnName);
sbRtn.Append("</Data></Cell>\r\n");
partRtn.Append("<Cell colSpan='3'><Data ss:Type=\"String\"></Data></Cell>\r\n");
}
else if (rownum > 0 && rownum <4)
{
if (rownum == 1)
{
sbRtn.Append("<Cell colSpan='3'><Data ss:Type=\"String\">短途用車(趟)</Data></Cell>\r\n");
}
else
{
sbRtn.Append("<Cell colSpan='3'><Data ss:Type=\"String\"></Data></Cell>\r\n");
}
partRtn.Append("<Cell><Data ss:Type=\"String\">");
partRtn.Append(dc.ColumnName);
partRtn.Append("</Data></Cell>\r\n");
//rownum += 3;
}
else if (rownum >3 && rownum <11)
{
if (rownum == 4)
{
sbRtn.Append("<Cell colSpan='7'><Data ss:Type=\"String\">長途用車(趟)</Data></Cell>\r\n");
}
else
{
sbRtn.Append("<Cell colSpan='3'><Data ss:Type=\"String\"></Data></Cell>\r\n");
}
partRtn.Append("<Cell><Data ss:Type=\"String\">");
partRtn.Append(dc.ColumnName);
partRtn.Append("</Data></Cell>\r\n");
//rownum += 7;
}
else
{
sbRtn.Append("<Cell rowSpan='2'><Data ss:Type=\"String\">");
sbRtn.Append(dc.ColumnName);
sbRtn.Append("</Data></Cell>\r\n");
}
rownum++;
}
sbRtn.Append("</Row>");
partRtn.Append("</Row>");
sbRtn.Append(partRtn);
return sbRtn.ToString();
}
#endregion
/// <summary>
/// Creates Excel Header
/// </summary>
/// <returns>Excel Header Strings</returns>
private static string ExcelHeader()
{
// Excel header
StringBuilder sb = new StringBuilder();
sb.Append("<?xml version=\"1.0\"?>\r\n");
sb.Append("<?mso-application progid=\"Excel.Sheet\"?>\r\n");
sb.Append("<Workbook xmlns=\"urn:schemas-microsoft-com:office:spreadsheet\" ");
sb.Append("xmlns:o=\"urn:schemas-microsoft-com:office:office\" ");
sb.Append("xmlns:x=\"urn:schemas-microsoft-com:office:excel\" ");
sb.Append("xmlns:ss=\"urn:schemas-microsoft-com:office:spreadsheet\" ");
sb.Append("xmlns:html=\"http://www.w3.org/TR/REC-html40\">\r\n");
sb.Append("<DocumentProperties xmlns=\"urn:schemas-microsoft-com:office:office\">");
sb.Append("<Author></Author>");
sb.Append("</DocumentProperties>");
sb.Append("<ExcelWorkbook xmlns=\"urn:schemas-microsoft-com:office:excel\">\r\n");
sb.Append("<ProtectStructure>False</ProtectStructure>\r\n");
sb.Append("<ProtectWindows>False</ProtectWindows>\r\n");
sb.Append("</ExcelWorkbook>\r\n");
return sb.ToString();
}
private static string ExcelWorkSheetOptions()
{
// This is Required Only Once , But this has to go after the First Worksheet's First Table
StringBuilder sb = new StringBuilder();
sb.Append("\r\n<WorksheetOptions xmlns=\"urn:schemas-microsoft-com:office:excel\">\r\n<Selected/>\r\n </WorksheetOptions>\r\n");
return sb.ToString();
}
}
導出方法示例
DataSet ds=....; OutExcelReport.DataSetToExcel(ds, filename, false, null, "");