在我们做我们的小组项目的时候,刚开始的时候我们用到的是Mvc+EF,用上了我们的ITOO框架。在最开始的计划,我们要用到瑞郎报表。可是呢,由于工期原因以及技术暂时没有实现,我们不得不想一个比较折中的方法,就是导出模版,让大家直接签到。

当我看到这个,并写出代码之后,感觉真的很不可思议,代码真的是太神奇了,师哥师姐也很神奇。现在给大家分享一下。

首先呢,我们要先用Word制作一个Word模版:

保存成Word 97-2003文档

其实后台服务端,打击也都知道,那个是相当简单的。我们来看一下MVC的cotroller里面和导出方法的JS方法是如何写的?

public ActionResult GetBidTRecordinfo(string bidProjectId)
{
//创建一个前台接收信息的实体集合
List<BidSignViewModel> bidSign = new List<BidSignViewModel>(); //创建一个接收后台传值得得集合
List<BidTRecorderViewModel> bidVM = new List<BidTRecorderViewModel>();
//调用方法
bidVM = ibidTRservies.GetBidTrecordInfo(bidProjectId);
if (bidVM.Count == 0)
{
bidSign = null;
}else {
for (int i = 0; i < bidVM.Count; i++) {
BidSignViewModel enSign = new BidSignViewModel();
enSign.BidName = bidVM[i].CompanyName;
enSign.BidAdress = bidVM[i].Address;
enSign.BidTel = bidVM[i].Tel;
enSign.OrganizationCode = bidVM[i].OrganizationCode; bidSign.Add(enSign);
}
}
return Json(bidSign, JsonRequestBehavior.AllowGet); }
#endregion #region 生成投标供应商签到表 ----李卫中---2015年12月17日00:36:45
/// <summary>
/// 生成投标供应商签到表
/// </summary>
/// <returns></returns>
public ActionResult ExportBidSign() {
//获取评标编号的招标信息
string BidProjectId = Request["BidProjectId"].ToString(); //获取项目名称
string BidRecordName = ibzrservies.GetBidRecordName(BidProjectId); #region 获取招标文件制作模板----李卫中----2015年12月17日00:37:19
//获得程序集根目录
string rootPath = AppDomain.CurrentDomain.BaseDirectory; //招标文件模板路径
var mainDocPath = rootPath + "/Content/投标供应商签到表/" + "投标供应商签到表.doc";
Aspose.Words.Document docMain = new Aspose.Words.Document(mainDocPath);
DocumentBuilder builder = new DocumentBuilder(docMain);
#endregion #region 替换模板中的内容常用字段---李卫中---2015年12月17日00:37:32
//获取系统当前时间
DateTime now = DateTime.Now;
//替换招标项目
docMain.Range.Replace("{ProjectName}", BidRecordName, false, false);
//替换招标编号
docMain.Range.Replace("{BidProjectId}", BidProjectId, false, false);
//替换评标报告生成日期
docMain.Range.Replace("{Now}", now.Year + "年" + now.Month + "月" + now.Day + "日", false, false); #endregion #region 嵌入评委打分表格表头----李卫中---2015年12月17日00:37:44
//开始添加值
builder.MoveToBookmark("table");
//添加表头数据
ArrayList tableHeadArray = new ArrayList();
//添加固定的前两列表头信息
tableHeadArray.Add("序号");
tableHeadArray.Add("供应商名称");
//builder.RowFormat.CellSpacing = 50;
tableHeadArray.Add("供应商代表签字");
tableHeadArray.Add("供应商地址");
tableHeadArray.Add("组织机构代码证");
tableHeadArray.Add("联系电话");
tableHeadArray.Add("备注");
//根据招标编号,获取所对应的所有评分项信息,评分名称作为第二列之后的表头信息
//获取评委打分项
for (int j = 0; j < tableHeadArray.Count; j++)
{
//插入单元格
builder.InsertCell();
//设置单元格边框样式及颜色
builder.CellFormat.Borders.LineStyle = LineStyle.Single;
builder.CellFormat.Borders.Color = System.Drawing.Color.Black;
//设置单元格宽度
builder.CellFormat.Width = 180;
builder.Write(tableHeadArray[j].ToString()); }
builder.EndRow();
#endregion #region 在word.doc中嵌入数据----李卫中---2015年12月17日01:03:29
//创建一个接收后台传值得得集合,查询招标商信息 List<BidTRecorderViewModel> bidVM = ibidTRservies.GetBidTrecordInfo(BidProjectId);
IList<IList<string>> companyName = new List<IList<string>>(); for (int i = 0; i < bidVM.Count; i++) //控制行数
{ //赋值区域
List<string> tempList = new List<string>();
tempList.Add((i + 1).ToString());
tempList.Add(bidVM[i].CompanyName);
tempList.Add(" ");
tempList.Add(" ");
tempList.Add(" ");
tempList.Add(bidVM[i].Tel);
tempList.Add(" ");
companyName.Add(tempList); }
for (int i = 0; i < bidVM.Count; i++) //控制行
{
for (int j = 0; j < tableHeadArray.Count; j++)//控制列
{
//插入单元格
builder.InsertCell();
//设置单元格边框样式及颜色
builder.CellFormat.Borders.LineStyle = LineStyle.Single;
builder.CellFormat.Borders.Color = System.Drawing.Color.Black;
//设置单元格宽度
builder.CellFormat.Width = 180;
builder.Write(companyName[i][j].ToString()); }
builder.EndRow();
} #endregion //将替换后的评标报告保存在以下路径
string outputPath = rootPath + "/Content/投标供应商签到表.doc";
//生成的评标报告的名称
string filename = "投标供应商签到表" + now.ToString("yyyy年mm月dd日") + ".doc";
//保存文件
docMain.Save(outputPath);
//将文件返回给视图
return File(outputPath, "application/msword", filename);
}
#endregion

JS模块:

<span style="font-size:18px;">//生成评分统计表
function ExportScoreSummary() {
var BidProjectId = document.getElementById('BidProjectId').value; window.location.href = '/BidSign/ExportBidSign?BidProjectId=' + BidProjectId;
}
</span>

总结

每一个模块方面学习,到要先接受,然后再创新,在我们暂时没有能力创新的时候,先学会接受,学会学习,才是一个更好的选择!

导出word使用模版的更多相关文章

  1. java导出word直接下载

    导出word工具类 package util; import java.io.IOException; import java.io.Writer; import java.util.Map; imp ...

  2. Java使用IText(VM模版)导出PDF,IText导出word(二)

    ===============action=========================== //退款导出word    public void exportWordTk() throws IOE ...

  3. PowerDesiger 15逆向生成工程E-R图及导出word表格

    应用环境:win8(64位)+oracle10g(32位)服务端+PowerDesigner15 需求:oracle数据库中的表结构是web工程框架hibernate 自动生成,现需要将数据库中已有的 ...

  4. C# 导出word文档及批量导出word文档(4)

          接下来是批量导出word文档和批量打印word文件,批量导出word文档和批量打印word文件的思路差不多,只是批量打印不用打包压缩文件,而是把所有文件合成一个word,然后通过js来调用 ...

  5. C# 导出word文档及批量导出word文档(2)

    aspose.word主要是通过把读取出来的数据放到datatable里,在datable里做相应的格式的调整,再导出到word文档里.mvc和webform最后导出的语句略有不同,在mvc的cont ...

  6. C# 导出Word

    导出word文档(无模版): using Microsoft.Office.Interop.Word; public static string CreateWordFile(CaseVM model ...

  7. ASP.NET MVC 导出Word报表

    最近要做MVC导出Word报表功能.查了查资料发现一个好用的插件就是Aspose.Word.这个插件也很有名气,也很好用. 1.首先就是引用该插件 2.填充Word模版 3.后台操作 private ...

  8. Spring MVC中使用POI导出Word

    内容绝大部分来源于网络 准备工作 准备[XwpfTUtil]工具类(来源于网络) 准备word模版 下载[XwpfTUtil]工具类 import org.apache.poi.xwpf.usermo ...

  9. powerdesigner 使用技巧 建模工具 导出sql 导出实体类 导出word

    显示comment列 Table Properties(表属性)=>Columns(列)=>Customize Columns and Filter(自定义列过滤) 勾上 comment ...

随机推荐

  1. opencart 引入 TWIG 模板引擎

     1.首先将 twig 包放入 system\library 目录. 2.在 system/startup.php 文件最后添加引入语句. require_once(DIR_SYSTEM . 'lib ...

  2. Django环境搭建

    1.安装好Python 2.7.10 2.下载解压Django Django-1.9.2.tar.gz cmd cd到解压缩目录(***) python setup.py install 3.检测是否 ...

  3. JS 异步加载的方法

    (1) defer,只支持IE : <script type="text/javascript" defer="defer"> </scrip ...

  4. jquery 中的一写常用方法

    $('form').submit(); // 表单提交 window.parent.location.reload(); // 子窗口刷新父页面 window.location.reload(); / ...

  5. 混合高斯模型:opencv中MOG2的代码结构梳理

    /* 头文件:OurGaussmix2.h */ #include "opencv2/core/core.hpp" #include <list> #include&q ...

  6. IOS-Gesture(手势识别)

    手势识别——Gesture Recognizer •iOS3.2版本之后,苹果推出了手势识别(Gesture Recognizer),其目的是: –简化开发者的开发难度 –统一用户体验 • •iOS目 ...

  7. Xcode添加注释

    VVDocumenter-Xcode,自动生成注释,感觉比较方便的插件,分享下,应该很多人都知道= = 在 https://github.com/onevcat/VVDocumenter-Xcode  ...

  8. [Android ] linux命令英文缩写的含义(方便记忆)

    du -sh */ reference to : http://blog.chinaunix.net/uid-27164517-id-3299073.html linux常用命令的英文单词缩写 命令缩 ...

  9. git安装--linux下的安装

    一般linux自带git版本很旧,会有一定问题,可以先卸载系统自带git: yum remove git下载及安装git: wget https://github.com/git/git/archiv ...

  10. Swift - 语言指南,来自github学习

    @SwiftLanguage 更新于 2016-6-6,更新内容详见 Issue 55.往期更新回顾详见<收录周报> 这份指南汇集了 Swift 语言主流学习资源,并以开发者的视角整理编排 ...