导出word使用模版
在我们做我们的小组项目的时候,刚开始的时候我们用到的是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使用模版的更多相关文章
- java导出word直接下载
导出word工具类 package util; import java.io.IOException; import java.io.Writer; import java.util.Map; imp ...
- Java使用IText(VM模版)导出PDF,IText导出word(二)
===============action=========================== //退款导出word public void exportWordTk() throws IOE ...
- PowerDesiger 15逆向生成工程E-R图及导出word表格
应用环境:win8(64位)+oracle10g(32位)服务端+PowerDesigner15 需求:oracle数据库中的表结构是web工程框架hibernate 自动生成,现需要将数据库中已有的 ...
- C# 导出word文档及批量导出word文档(4)
接下来是批量导出word文档和批量打印word文件,批量导出word文档和批量打印word文件的思路差不多,只是批量打印不用打包压缩文件,而是把所有文件合成一个word,然后通过js来调用 ...
- C# 导出word文档及批量导出word文档(2)
aspose.word主要是通过把读取出来的数据放到datatable里,在datable里做相应的格式的调整,再导出到word文档里.mvc和webform最后导出的语句略有不同,在mvc的cont ...
- C# 导出Word
导出word文档(无模版): using Microsoft.Office.Interop.Word; public static string CreateWordFile(CaseVM model ...
- ASP.NET MVC 导出Word报表
最近要做MVC导出Word报表功能.查了查资料发现一个好用的插件就是Aspose.Word.这个插件也很有名气,也很好用. 1.首先就是引用该插件 2.填充Word模版 3.后台操作 private ...
- Spring MVC中使用POI导出Word
内容绝大部分来源于网络 准备工作 准备[XwpfTUtil]工具类(来源于网络) 准备word模版 下载[XwpfTUtil]工具类 import org.apache.poi.xwpf.usermo ...
- powerdesigner 使用技巧 建模工具 导出sql 导出实体类 导出word
显示comment列 Table Properties(表属性)=>Columns(列)=>Customize Columns and Filter(自定义列过滤) 勾上 comment ...
随机推荐
- dump、cpio、tar、dd四种备份工具比较
原文 http://blog.csdn.net/ether_lai/article/details/12656219 dump dump可执行文件系统增量备份的存储操作 ,dump 可将目录或整个文 ...
- 设定报表变量的CharSpacing
设定报表变量的CharSpacing字符间距,预览时都没问题, 间距大的字与字之间拉得比较大,但在大多数电脑打印时和预览的结果一样,但有些电脑打印出来却跟没有设间距一样?
- stream的seek方法实例
using (FileStream outStream = new FileStream(@"D:\12.txt", FileMode.Open)) { using (FileSt ...
- nyoj1000_快速幂_费马小定理
又见斐波那契数列 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 斐波那契数列大家应该很熟悉了吧.下面给大家引入一种新的斐波那契数列:M斐波那契数列. M斐波那契数列 ...
- H5 前端页面适配响应式
辞职有半个月了,面试了几家公司,还在挣扎中.... 不废话,H5页面适配成响应式,可以用百分比或者rem. rem是相对于html根元素的单位,可以根据根元素的大小做出等比缩放, 通常,假如设置,ht ...
- Class和ClassLoader的getResourceAsStream区别
这两个方法还是略有区别的, 以前一直不加以区分,直到今天发现要写这样的代码的时候运行 错误, 才把这个问题澄清了一下. 基本上,两个都可以用于从 classpath 里面进行资源读取, classp ...
- Apple Swift编程语言入门教程
Apple Swift编程语言入门教程 作者: 日期: 布衣君子 2015.09.22 目录 1 简介 2 Swift入门 3 简单值 4 控制流 5 函数与闭包 6 对象与类 ...
- NodeVisitor的使用-遍历Geode节点并在它与父节点之间添加一个LOD节点
#include <osg\NodeVisitor>#include <osg\MatrixTransform>#include <osg\PagedLOD>#in ...
- Mybatis 学习笔记1
---恢复内容开始--- 什么是 MyBatis ? MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获 ...
- UbuntuLinux安装Mysql
1.安装Mysql5.7 方法:手动安装5.7 One: $ wget http://dev.mysql.com/get/mysql-apt-config_0.6.0-1_all.deb 下载 ...