在我们做我们的小组项目的时候,刚开始的时候我们用到的是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. 多线程BackroundWorker 使用

    参考文章:http://www.cnblogs.com/inforasc/archive/2009/10/12/1582110.html using System; using System.Coll ...

  2. cxGrid 增加序号 (非数据库绑定模式) (测试通过)

    cxGrid 增加序号 (非数据库绑定模式) ----------------------------------- 1. 选在 adoQuery 控件 , 鼠标右键菜单中 选择 Fields Edi ...

  3. SAP SMARTFORM 变量显示技巧

    &symbol& (括号中,小写字母为变量) &symbol& 屏蔽从第一位开始的N位&symbol (n)&       只显示前N位&sym ...

  4. 头文件algorithm中的常用函数

    非修改性序列操作(12个) 循环         对序列中的每个元素执行某操作         for_each() 查找         在序列中找出某个值的第一次出现的位置         fin ...

  5. jquery-validation-1.13.1 自定义验证正则

    /*** check Mobile***********************/ jQuery.validator.addMethod("isMobile", function( ...

  6. September 25th 2016 Week 40th Sunday

    Everything is good in its season. 万物逢时皆美好. Don't lose hope. Remeber that even a dog has its day. Onc ...

  7. 躲避大龙(codevs 1961)

    题目描述 Description 你早上起来,慢悠悠地来到学校门口,发现已经是八点整了!(这句话里有一个比较重要的条件) 学校共有N个地点,编号为1~N,其中1号为学校门口(也就是你现在所处的位置), ...

  8. Destination Host Unreachable

    自己的Linux 机器连不上服务器了,ping XXXX的时候报这个错误了 看了一下是因为IP的原因==>进入Linux的图形界面==>System==>Administration ...

  9. Android 添加cookie

    /** * 添加cookie * * @param url */ private void setCookie(String url) { // 获取uid String uid = UserData ...

  10. java ---线程wait/notify/sleep/yield/join

    一.线程的状态 Java中线程中状态可分为五种:New(新建状态),Runnable(就绪状态),Running(运行状态),Blocked(阻塞状态),Dead(死亡状态). New:新建状态,当线 ...