在我们做我们的小组项目的时候,刚开始的时候我们用到的是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. 最近开始做Android了

    最近开始做Android,在学习的过程中发现找以前知识很不方便啊,于是决定以后还是把知识记录在博客里吧,说不定也能为他人提供参考!

  2. CString之GetBuffer与ReleaseBuffer

    我们知道,CString是MFC中提供的方便字符串操作的一个类,非常好使,具有自动动态内存管理功能. GetBuffer()主要作用是将字符串的缓冲区长度锁定: ReleaseBuffer()则是解除 ...

  3. js的json转换

    静态页面是: data:[{ value:2.5, itemStyle:{ normal:{color:'#4a90e2'} } },{ value:2.5, itemStyle:{ normal:{ ...

  4. 【leetcode】Evaluate Reverse Polish Notation(middle)

    Evaluate the value of an arithmetic expression in Reverse Polish Notation. Valid operators are +, -, ...

  5. win7自动登录桌面

    control userpasswords2 在开始菜单中搜索“运行”,回车打开,或者Win+R打开运行窗口. 键入“control userpasswords2”或者“rundll32 netplw ...

  6. mvn命令备忘

    转换成eclipse项目mvn eclipse:eclipse 跳过testmvn install -Dmaven.test.skip=true mvn clean install -DskipTes ...

  7. 中文和unicode互转

    public class Test { public static void main(String[] args) { String uname="欧阳红"; for (int ...

  8. c语言if语句

    #include<stdio.h>#include<windows.h>#include <limits.h>#include <math.h>int ...

  9. DB2 Z/os Load utility 使用

    Use the LOAD online utility to load one or more tables of a table space. The LOAD utility loads reco ...

  10. Hbernate映射类型

    对应oracle中的数据库:用timestamp