ASP.NET MVC 導(dǎo)出Word報(bào)表
最近要做MVC導(dǎo)出Word報(bào)表功能。查了查資料發(fā)現(xiàn)一個(gè)好用的插件就是Aspose.Word。這個(gè)插件也很有名氣,也很好用。
1.首先就是引用該插件

2.填充Word模版

3.后臺(tái)操作
private List<double> QuaterAirPM10AvgVolReport(string stns, DateTime start, DateTime end, Aspose.Words.DocumentBuilder builder, out DataTable dt, out List<double> widthList,string isMax)
{
dt = QuaterPM10AvgVol (stns, start, end,isMax);
widthList = new List<double>();
double[] colWidth = new double[] { 50, 118, 117, 50, 118, 117 };
string[] colName = new string[] { "排序", "城市", start.Year + "年" + start.Month + "~"+end.Month+"月濃度(μg/m3)", "排序", "城市", "較" + start.AddYears(-1).Year + "年同期增幅" };
builder.MoveToBookmark("table3");
Aspose.Words.Tables.Table table = builder.StartTable();//開始畫Table
builder.InsertCell();
builder.CellFormat.Borders.LineStyle = LineStyle.Single;
builder.CellFormat.Borders.Color = System.Drawing.Color.Black;
builder.CellFormat.VerticalMerge = CellMerge.First;
builder.CellFormat.Width = 285;
builder.ParagraphFormat.Alignment = ParagraphAlignment.Center;
// builder.CellFormat.VerticalAlignment = Aspose.Words.Tables.CellVerticalAlignment.Center;
builder.Write("按平均濃度排序");
builder.InsertCell();
builder.CellFormat.Borders.LineStyle = LineStyle.Single;
builder.CellFormat.Borders.Color = System.Drawing.Color.Black;
builder.ParagraphFormat.Alignment = ParagraphAlignment.Center;
// builder.CellFormat.VerticalAlignment = Aspose.Words.Tables.CellVerticalAlignment.Center;
builder.CellFormat.VerticalMerge = CellMerge.None;
builder.CellFormat.Width = 285;
builder.Write("按" + start.AddYears(-1).Year + "年同期增幅排序");
builder.EndRow();
AsposeCreateCell(builder, colWidth[0], colName[0]);
AsposeCreateCell(builder, colWidth[1], colName[1]);
AsposeCreateCell(builder, colWidth[2], colName[2]);
AsposeCreateCell(builder, colWidth[3], colName[3]);
AsposeCreateCell(builder, colWidth[4], colName[4]);
AsposeCreateCell(builder, colWidth[5], colName[5]);
builder.EndRow();
//開始添加值
for (var i = 0; i < dt.Rows.Count; i++)
{
if (dt.Rows[i]["CityName"] == "12個(gè)考核地市" || dt.Rows[i]["CityName"] == "全省")
{
builder.InsertCell();
builder.CellFormat.Borders.LineStyle = LineStyle.Single;
builder.CellFormat.Borders.Color = System.Drawing.Color.Black;
builder.CellFormat.VerticalMerge = CellMerge.First;
builder.CellFormat.Width = 168;
builder.ParagraphFormat.Alignment = ParagraphAlignment.Center;
builder.Write(dt.Rows[i]["CityName"].ToString());
builder.InsertCell();
builder.CellFormat.Borders.LineStyle = LineStyle.Single;
builder.CellFormat.Borders.Color = System.Drawing.Color.Black;
builder.ParagraphFormat.Alignment = ParagraphAlignment.Center;
builder.CellFormat.VerticalMerge = CellMerge.None;
builder.CellFormat.Width = 117;
builder.Write(dt.Rows[i]["PM10ATI"].ToString());
builder.InsertCell();
builder.CellFormat.Borders.LineStyle = LineStyle.Single;
builder.CellFormat.Borders.Color = System.Drawing.Color.Black;
builder.ParagraphFormat.Alignment = ParagraphAlignment.Center;
builder.CellFormat.VerticalMerge = CellMerge.None;
builder.CellFormat.Width = 168;
builder.Write(dt.Rows[i]["qnCityName"].ToString());
builder.InsertCell();
builder.CellFormat.Borders.LineStyle = LineStyle.Single;
builder.CellFormat.Borders.Color = System.Drawing.Color.Black;
builder.ParagraphFormat.Alignment = ParagraphAlignment.Center;
builder.CellFormat.VerticalMerge = CellMerge.None;
builder.CellFormat.Width = 117;
builder.Write(dt.Rows[i]["tqbh"].ToString() + "%");
}
else
{
AsposeCreateCell(builder, colWidth[0], dt.Rows[i]["Sort"].ToString());
AsposeCreateCell(builder, colWidth[1], dt.Rows[i]["CityName"].ToString());
AsposeCreateCell(builder, colWidth[2], dt.Rows[i]["PM10ATI"].ToString());
AsposeCreateCell(builder, colWidth[3], dt.Rows[i]["qnSort"].ToString());
AsposeCreateCell(builder, colWidth[4], dt.Rows[i]["qnCityName"].ToString());
AsposeCreateCell(builder, colWidth[5], dt.Rows[i]["tqbh"].ToString() + "%");
}
builder.EndRow();
}
builder.EndTable();
return widthList;
}
其中有幾個(gè)注意的地方 builder.CellFormat.VerticalMerge = CellMerge.None;CellMerge是枚舉類型,經(jīng)常用到畫復(fù)雜的表格,或者是合并單元格。還有First和Previous。先要得到DataTable數(shù)據(jù),最后對(duì)數(shù)據(jù)進(jìn)行操作就行了。
4.輸出文檔
public JsonResult QuaterResponse()
{
bool result;
string quarter = Request["quarter"].ToString();
string stns = Request["stns"].ToString();
string isMax = Request["ismax"].ToString();
DateTime startTime = Convert.ToDateTime(Request["startdate"]);
DateTime endTime = Convert.ToDateTime(Request["enddate"]);
string tmppath = Server.MapPath("~/Document/Model/QuaterReport.docx");
string path = Server.MapPath("~/Document/Export/QuaterReport.doc");
Aspose.Words.Document doc = new Document(tmppath);
Aspose.Words.DocumentBuilder builder = new DocumentBuilder(doc);
doc.Range.Bookmarks["title"].Text = startTime.Year+"年"+quarter+"湖北省環(huán)境空氣質(zhì)量監(jiān)測(cè)情況綜述";
doc.Range.Bookmarks["title1"].Text = "表1 "+quarter+"空氣質(zhì)量等級(jí)";
doc.Range.Bookmarks["title2"].Text = "表2" +quarter+"優(yōu)良天數(shù)達(dá)標(biāo)率情況表";
doc.Range.Bookmarks["title3"].Text = "表3 "+quarter+"空氣可吸入顆粒物(PM10)平均濃度情況表";
doc.Range.Bookmarks["title4"].Text = "表4 "+quarter+"空氣可吸入顆粒物(PM2.5)平均濃度情況表";
doc.Range.Bookmarks["title5"].Text = "表5"+quarter+" 境空氣氣態(tài)污染物平均濃度情況表";
doc.Range.Bookmarks["title6"].Text = "表6 "+quarter+"環(huán)境空氣質(zhì)量綜合指數(shù)情況表";
DataTable dt;
List<double> widthList;
try
{
doc.Range.Bookmarks["table1"].Text = ""; // 清掉標(biāo)示
QuaterAirPerencetReport( stns, startTime, endTime, builder, out dt, out widthList,isMax);
doc.Range.Bookmarks["table2"].Text = "";
QuaterAirYldblReport(stns, startTime, endTime, builder,quarter, out dt, out widthList,isMax);
doc.Range.Bookmarks["table3"].Text = "";
QuaterAirPM10AvgVolReport(stns, startTime, endTime, builder, out dt, out widthList,isMax);
doc.Range.Bookmarks["table4"].Text = "";
QuaterAirPM25AvgVolReport(stns, startTime, endTime, builder, out dt, out widthList,isMax);
doc.Range.Bookmarks["table5"].Text = "";
QuaterOtherAvgVolReport(stns, startTime, endTime, builder, out dt, out widthList,isMax);
doc.Range.Bookmarks["table6"].Text = "";
QuaterZHIndexReport(stns, startTime, endTime, builder, out dt, out widthList,isMax);
doc.Save(path, Aspose.Words.SaveFormat.Doc);
// System.Diagnostics.Process.Start(path);//打開文檔
// return View("QuaterReport");
result = true;
}
catch (Exception)
{
result = false;
}
return Json(result);
}
以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!
相關(guān)文章
.Net極限生產(chǎn)力之分表分庫(kù)全自動(dòng)化Migrations?Code-First
這篇文章主要介紹了.Net極限生產(chǎn)力之分表分庫(kù)全自動(dòng)化Migrations?Code-First,輕量級(jí)針對(duì)分表分庫(kù)讀寫分離的解決方案,具有零依賴、零學(xué)習(xí)成本、零業(yè)務(wù)代碼入侵適配2022-07-07
asp.net使用jquery模板引擎jtemplates呈現(xiàn)表格
這篇文章主要介紹了asp.net使用jquery模板引擎jtemplates呈現(xiàn)表格的示例,大家參考使用吧2014-01-01
.NET集成DeveloperSharp實(shí)現(xiàn)高效分頁(yè)與無(wú)主鍵分頁(yè)
DeveloperSharp系列近期又被制造業(yè)ERP、民航飛行App、建筑BIM、電力掌上營(yíng)業(yè)廳、等多家大型采用,站在巨人的肩膀上你能走的更遠(yuǎn),這篇文章主要介紹了.NET集成DeveloperSharp實(shí)現(xiàn)高效分頁(yè)與無(wú)主鍵分頁(yè),需要的朋友可以參考下2024-06-06
解決.NET?Core企業(yè)微信openapi回調(diào)地址請(qǐng)求不通過(guò)的問(wèn)題
這篇文章介紹了解決.NET?Core企業(yè)微信openapi回調(diào)地址請(qǐng)求不通過(guò)的問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06
asp.net core 使用 TestServer 來(lái)做集成測(cè)試的方法
這篇文章主要介紹了asp.net core 使用 TestServer 來(lái)做集成測(cè)試,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11
asp.net SAF 中緩存服務(wù)的實(shí)現(xiàn)
對(duì)緩存的興趣源于張子陽(yáng)寫的一篇文章《SAF 中緩存服務(wù)的實(shí)現(xiàn)》中的一個(gè)例子:2008-08-08

