最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

ASP.NET MVC 导出Word报表

来源:懂视网 责编:小采 时间:2020-11-27 22:35:54
文档

ASP.NET MVC 导出Word报表

ASP.NET MVC 导出Word报表:最近要做MVC导出Word报表功能。查了查资料发现一个好用的插件就是Aspose.Word。这个插件也很有名气,也很好用。 1.首先就是引用该插件 2.填充Word模版 3.后台操作 private List<double> QuaterAirPM10AvgVolReport(st
推荐度:
导读ASP.NET MVC 导出Word报表:最近要做MVC导出Word报表功能。查了查资料发现一个好用的插件就是Aspose.Word。这个插件也很有名气,也很好用。 1.首先就是引用该插件 2.填充Word模版 3.后台操作 private List<double> QuaterAirPM10AvgVolReport(st

最近要做MVC导出Word报表功能。查了查资料发现一个好用的插件就是Aspose.Word。这个插件也很有名气,也很好用。

1.首先就是引用该插件

2.填充Word模版

3.后台操作

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个考核地市" || 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;
 }

其中有几个注意的地方 builder.CellFormat.VerticalMerge = CellMerge.None;CellMerge是枚举类型,经常用到画复杂的表格,或者是合并单元格。还有First和Previous。先要得到DataTable数据,最后对数据进行操作就行了。

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+"湖北省环境空气质量监测情况综述";
 doc.Range.Bookmarks["title1"].Text = "表1 "+quarter+"空气质量等级";
 doc.Range.Bookmarks["title2"].Text = "表2" +quarter+"优良天数达标率情况表";
 doc.Range.Bookmarks["title3"].Text = "表3 "+quarter+"空气可吸入颗粒物(PM10)平均浓度情况表";
 doc.Range.Bookmarks["title4"].Text = "表4 "+quarter+"空气可吸入颗粒物(PM2.5)平均浓度情况表";
 doc.Range.Bookmarks["title5"].Text = "表5"+quarter+" 境空气气态污染物平均浓度情况表";
 doc.Range.Bookmarks["title6"].Text = "表6 "+quarter+"环境空气质量综合指数情况表";
 DataTable dt;
 List<double> widthList;
 try
 {
 doc.Range.Bookmarks["table1"].Text = ""; // 清掉标示 
 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);
 }

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

ASP.NET MVC 导出Word报表

ASP.NET MVC 导出Word报表:最近要做MVC导出Word报表功能。查了查资料发现一个好用的插件就是Aspose.Word。这个插件也很有名气,也很好用。 1.首先就是引用该插件 2.填充Word模版 3.后台操作 private List<double> QuaterAirPM10AvgVolReport(st
推荐度:
标签: word 表格 生成
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top