在我们做我们的小组项目的时候,刚开始的时候我们用到的是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. ios 在storyboard 和 xib中,显示自定义view的预览效果

    发现FSCalendar这个控件能在xib中显示预览效果,是怎么实现的呢?其中涉及的知识又有哪些? 主要就是IBInspectable 和 IB_DESIGNABLE 先看 IBInspectable ...

  2. Linux下安装Scala

    Linux下安装Scala和Windows下安装类似,步骤如下: 首先访问下载链接:http://www.scala-lang.org/download/默认这里下载的是Windows版本,这时点击上 ...

  3. Solr集群更新配置的方式

    solr集群中配置文件是经常更新的,频率最高的也就是schema.xml和solrconfig.xml这两个配置文件了,对于更新配置文件之前,我们先了解一下集群项目结构 由于在集群模式下,solrco ...

  4. 不知道数据库中表的列类型的前提下,使用JDBC正确的取出数据

    概要: 使用jdbc 如果在不知道表结构的情况下,如何读出表信息? 使用ResultSetMetaData; 然后使用getColumnType 获取column 类型 使用getColumnName ...

  5. [转载]Masonry介绍与使用实践(快速上手Autolayout)

    原博地址 http://adad184.com/2014/09/28/use-masonry-to-quick-solve-autolayout/ 前言 1 MagicNumber -> aut ...

  6. asp.net 后台获取input的值

    前台:<input id="test" value="" runat="server" /> 只要架上runat="s ...

  7. supersr--class_copyIvarList和class_copyPropertyList的区别

    class_copyPropertyList返回的仅仅是对象类的属性(@property申明的属性), 而class_copyIvarList返回类的所有属性和变量(包括在@interface大括号中 ...

  8. Hyper snap

    图像->分辨率,设置成300dpi,一般论文的分辨率要求.

  9. 群内大神与你交流WEB经验 业内专家指点就职技巧

    就知道你是一个有理想要抱负的人,不会满足于做一个初级的前端开发工程师.在接下来的这个阶段,我们将走上前端开发的进阶之路,将自己的能力再往上拔高一个等级.同样,薪资也会往上升一个等级!但是,如果你是一个 ...

  10. CLR via C#(14)-可空值类型,关于?和??的故事

    我们都知道,值类型是不能为Null的,但是在实际应用中有些情形却需要将值类型置为null.因此,CLR中引用了可空值类型的用法.今天的文章中见到最多的符号估计就是?了吧. ?——初识可空值类型 1.  ...