码迷,mamicode.com
首页 > Web开发 > 详细

MVC4 导出word

时间:2015-01-09 19:12:30      阅读:202      评论:0      收藏:0      [点我收藏+]

标签:

添加程序包 DocX

using System.IO;
using Novacode;

        /// <summary>
        /// 导出Word
        /// </summary>
        public FileResult GetExportWord()
        {
            var items = _service.GetAll();

            //string path = @"~/Content/Templates/Vote.docx";
            //string path = @"/Content/Templates/Vote.docx";

            string path = Server.MapPath("/Content/Templates/Vote.docx");
            string fileName = "票决结果.docx";
            DocX doc;
            try
            {
                // Store a global reference to the loaded document.
                doc = DocX.Load(path);
                var table = doc.Tables[0];

                var row = table.Rows[1];
                for (var i = 1; i < items.Count; i++)
                {
                    table.InsertRow(row, i + 1);
                }
                for (var i = 0; i < items.Count; i++)
                {
                    var item = items[i];
                    var curRow = table.Rows[i + 1];

                    curRow.Cells[0].MarginTop = 5;
                    curRow.Cells[0].MarginBottom = 5;
                    curRow.Cells[0].Paragraphs[0].InsertText((i + 1).ToString());
                    curRow.Cells[1].MarginTop = 5;
                    curRow.Cells[1].MarginBottom = 5;
                    curRow.Cells[1].Paragraphs[0].InsertText(item.Name ?? "");
                    curRow.Cells[2].MarginTop = 5;
                    curRow.Cells[2].MarginBottom = 5;
                    curRow.Cells[2].Paragraphs[0].InsertText(item.Company ?? "");
                    curRow.Cells[3].MarginTop = 5;
                    curRow.Cells[3].MarginBottom = 5;
                    curRow.Cells[3].Paragraphs[0].InsertText(item.Email ?? "");
                    curRow.Cells[4].MarginTop = 5;
                    curRow.Cells[4].MarginBottom = 5;
                    curRow.Cells[4].Paragraphs[0].InsertText(item.Location ?? "");
                    curRow.Cells[5].MarginTop = 5;
                    curRow.Cells[5].MarginBottom = 5;
                    curRow.Cells[4].Paragraphs[0].InsertText(item.Location ?? "");
                    curRow.Cells[6].MarginTop = 5;
                    curRow.Cells[6].MarginBottom = 5;
                    curRow.Cells[4].Paragraphs[0].InsertText(item.Location ?? "");
                    curRow.Cells[7].MarginTop = 5;
                    curRow.Cells[7].MarginBottom = 5;
                    curRow.Cells[4].Paragraphs[0].InsertText(item.Location ?? "");
                }

                var stream = new MemoryStream(256);
                doc.SaveAs(stream);
                stream.Position = 0;

                return File(stream, "application/vnd.ms-word", fileName);
            }

                // The template ‘InvoiceTemplate.docx‘ does not exist, so create it.
            catch (Exception er)
            {
                throw er;
            }
        }

 

MVC4 导出word

标签:

原文地址:http://www.cnblogs.com/yechangzhong-826217795/p/4213912.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!