using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Reflection;
using System.IO;
using System.Data.SqlClient;
using System.Data;
namespace WebApplication1
{
    public partial class PrintWord : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            // QueryDataSet();
        }
        /// <summary>
        /// 导出
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void btnPrint_Click(object sender, EventArgs e)
        {
            Print();
        }
        /// <summary>
        /// 导出Word 
        ///生成word解决方案
        ///1.先引入模板
        ///2.判断是否和查询数据集一样的行,如果小于数据集就要增到行数
        ///3. 获取表格并且并且为每一个单元格赋值
        ///4.根据不同的条件来设置单元格的颜色变化
        /// </summary>
        private void Print()
        {
            //先引入word
            Microsoft.Office.Interop.Word.Application app; //明一个应用
            Microsoft.Office.Interop.Word.Document doc;  //创建一个文档
            string TemplateFile = ""; // 声明要使用的模板名称
            string FileName = ""; // 新文件的路径名称
            string Fname = ""; //新文件名称
            app = new Microsoft.Office.Interop.Word.Application();//创建实例应用
            doc = new Microsoft.Office.Interop.Word.Document();  //创建实例文档
            TemplateFile = Server.MapPath("~/test/半月带预测-长安汽车每日快报2015010x.dot"); //Server.MapPath("~/test/CAXSMB.dot");//找到模板
            Fname = DateTime.Now.ToString("测试相同的文档名试试") + ".doc";//创建新文件的名称 yyyymmddhhmmss
            FileName = Server.MapPath("~/test/download/" + Fname);//新文件的路径
            //判断有相同的文档就要删除
            if (File.Exists(FileName))
            {
                File.Delete(FileName);
            }
            File.Copy(TemplateFile, FileName);//把模板拷贝到新文件
            //为新文件设置属性
            object Obj_FileName = FileName;
            object Visible = false;
            object ReadOnly = false;
            object missing = System.Reflection.Missing.Value;
            //创建新文档
            doc = app.Documents.Open(
            ref Obj_FileName, ref missing, ref ReadOnly, ref missing,
            ref missing, ref missing, ref missing, ref missing,
            ref missing, ref missing, ref missing, ref Visible,
            ref missing, ref missing, ref missing,
            ref missing);
            //增加表格
            //DataSet ds = GetDataSet();//获取程序集合
            //int dsCount = ds.Tables[0].Rows.Count;//得到数据库表中的数据
            //int docCount = doc.Tables[1].Rows.Count; //得到文档中表格的数据
            //if (dsCount > docCount) //当实际数据大约表格数据的时候创建行
            //{
            //    //开始增加行
            //    Microsoft.Office.Interop.Word.Table newTable = doc.Tables[1];
            //    for (int row = 0; row < dsCount - docCount; row++)
            //    {
            //        object beforeRow = doc.Tables[1].Rows[docCount-1];
            //        doc.Tables[1].Rows.Add(ref beforeRow); // 行添加到表格中
            //    }
            //}
            doc.Activate();
        
            // 匹配表格数据集
           
            Microsoft.Office.Interop.Word.Document odoc = GetDocument(FileName);//获取新生的文档
            DataSet ds = GetDataSet();//获取程序集合
            //开始判断里面有几个表格/因为模板里面有三张表
            for (int tablePos = 1; tablePos <= odoc.Tables.Count; tablePos++)
            {
                //都一张表的时候
                if (tablePos == 1)
                {
                    int dsCount = ds.Tables[0].Rows.Count;//得到数据库表中的数据
                    int docCount = odoc.Tables[1].Rows.Count; //得到文档中表格的数据
                    if (dsCount > docCount) //当实际数据大约表格数据的时候创建行
                    {
                        //开始增加行
                        Microsoft.Office.Interop.Word.Table newTable = doc.Tables[1];
                        for (int row = 0; row < (dsCount - docCount)+1; row++)
                        {
                            object beforeRow = newTable.Rows[docCount];
                            newTable.Rows.Add(ref beforeRow); // 行添加到表格中
                        }
                    }
                    //表格完成之后开始增加数据,为单元格赋值
                    for (int rcount = 0; rcount < ds.Tables[0].Rows.Count; rcount++)
                    {
                        for (int ccount = 0; ccount < ds.Tables[0].Columns.Count; ccount++)
                        {
                            //doc.Tables[1].Rows[rowPos].Cells[columPos].Range.Text
                            string strText = ds.Tables[0].Rows[rcount][ccount].ToString();
                            doc.Tables[1].Rows[rcount+2].Cells[ccount + 1].Range.Text = strText;//从第二行开始算起
                            if (strText == "r")
                            {
                                doc.Tables[1].Rows[rcount+2].Cells[ccount + 1].Range.Shading.BackgroundPatternColor = Microsoft.Office.Interop.Word.WdColor.wdColorLightBlue;
                            }
                        }
                    }
                }
            }
            //关闭进程
            object IsSave = true;
            doc.Close(ref IsSave, ref missing, ref missing);
            app.Quit(ref IsSave, ref missing, ref missing);            //关闭word进程
            string url = "~/test/download/" + Fname; ;
            Response.Redirect(url);
            System.Runtime.InteropServices.Marshal.ReleaseComObject(app);    //释放内存空间 
        }
        /// <summary>
        /// 查询数据集
        /// </summary>
        /// <returns></returns>
        public DataSet GetDataSet()
        {
            string sConnectionString = "server=.;uid=sa;pwd=123456;database=xiaoshoudb";
            SqlConnection objConn = new SqlConnection(sConnectionString);
            objConn.Open();
            SqlDataAdapter da = new SqlDataAdapter("select * from  yuexiaoshou", objConn);
            DataSet ds = new DataSet();
            da.Fill(ds);
            objConn.Close();
            return ds;
        }
        /// <summary>
        /// 根据文件地址得到该文件下属性
        /// </summary>
        /// <param name="fileRoad"></param>
        /// <returns></returns>
        public Microsoft.Office.Interop.Word.Document GetDocument(string fileRoad)
        {
            Microsoft.Office.Interop.Word.Application app;
            app = new Microsoft.Office.Interop.Word.Application();
            object oFileName = fileRoad;  //Server.MapPath(fileRoad);//根据word的路径         //("~/test/测试读写.docx");  // @"F:\数据库.docx";
            object oReadOnly = false;
            object oMissing = System.Reflection.Missing.Value;
            Microsoft.Office.Interop.Word._Application oWord;
            Microsoft.Office.Interop.Word.Document oDoc;
            oWord = new Microsoft.Office.Interop.Word.Application();
            oWord.Visible = false;
            oDoc = oWord.Documents.Open(ref oFileName, ref oMissing, ref oReadOnly, ref oMissing, ref oMissing,
            ref oMissing, ref oMissing, ref oMissing, ref oMissing, ref oMissing, ref oMissing, ref oMissing);
            return oDoc;
        }
    }
}

C# 导出word 表格代码的更多相关文章

  1. poi导出word表格跨行

    DataCommon.java package com.ksource.pwlp.model.statistic; public class DataCommon { private Long id; ...

  2. poi导出word表格详解 超详细了

    转:非常感谢原作者 poi导出word表格详解 2018年07月20日 10:41:33 Z丶royAl 阅读数:36138   一.效果如下 二.js代码 function export_word( ...

  3. PowerDesiger 15逆向生成工程E-R图及导出word表格

    应用环境:win8(64位)+oracle10g(32位)服务端+PowerDesigner15 需求:oracle数据库中的表结构是web工程框架hibernate 自动生成,现需要将数据库中已有的 ...

  4. c#(.net) 导出 word表格

    做了差不多一周的导出Word,现在把代码贴出来   : ExportWord.cs using System; using System.Collections.Generic; using Syst ...

  5. poi导出word表格

    代码如下: package com.ksource.pwlp.util; import java.io.FileOutputStream; import java.math.BigInteger; i ...

  6. .net使用AsposeWord导出word table表格

    本文为原创,转载请注明出处 1.前言 .net平台下导出word文件还可以使用Microsoft.Office.Interop和NPOI,但是这两者都有缺点,微软的Office.Interop组件需要 ...

  7. Java使用velocity导出word

    效果展示: 使用word编辑好模板

  8. Freemarker + xml 实现Java导出word

    前言 最近做了一个调查问卷导出的功能,需求是将维护的题目,答案,导出成word,参考了几种方案之后,选择功能强大的freemarker+固定格式之后的wordxml实现导出功能.导出word的代码是可 ...

  9. 使用NPOI2.1.3.1版本导出word附带表格和图片

    原文:http://www.cnblogs.com/afutureBoss/p/4074397.html?utm_source=tuicool&utm_medium=referral 最近项目 ...

随机推荐

  1. Linux快速入门教程-进程管理ipcs命令学习

    使用Linux系统必备的技能之一就是Linux进程管理,系统运行的过程正是无数进程在运行的过程.这些进程的运行需要占用系统的内存等资源,做好系统进程的管理,对于我们合理分配.使用系统资源有非常大的意义 ...

  2. 码书:编码与解码的战争 PDF 下载

    码书:编码与解码的战争 PDF 下载 下载地址:https://pan.baidu.com/s/14Y_krHh-unOv4g2KYFFDgQ 如需分享码:[打开微信]->[扫描右侧二维码]-& ...

  3. Oracle开发常用函数 max 最大数 自动加 1 的模式

    create sequence bs_com_seq increment by 1 start with 1 minvalue 1 maxvalue 999999 cycle nocache orde ...

  4. 【webpack结合React开发环境配置】React开发环境配置之Webpack结合Babel8.x版本安装的正确姿势(Webpack最新版4.x结合Babel8.x环境配置步骤)

    1. 安装cnpmnpm install -g cnpm --registry=https://registry.npm.taobao.org[使用淘宝镜像]2. 初始化package.json文件c ...

  5. CodeForcesGym 100735G LCS Revised

    LCS Revised Time Limit: 2000ms Memory Limit: 65536KB This problem will be judged on CodeForcesGym. O ...

  6. BNUOJ 3958 MAX Average Problem

    MAX Average Problem Time Limit: 3000ms Memory Limit: 65536KB 64-bit integer IO format: %lld      Jav ...

  7. Alliances

    树国是一个有n个城市的国家,城市编号为1∼n.连接这些城市的道路网络形如一棵树, 即任意两个城市之间有恰好一条路径.城市中有k个帮派,编号为1∼k.每个帮派会占据一些城市,以进行非法交易.有时帮派之间 ...

  8. nyoj_513_A+B Problem IV_20130131532

    A+B Problem IV 时间限制:1000 ms  |           内存限制:65535 KB 难度:3   描述 acmj最近发现在使用计算器计算高精度的大数加法时很不方便,于是他想着 ...

  9. N天学习一个linux命令之yum

    yum命令 用途 yum(Yellowdog Updater Modified),RedHat系Linux操作系统包管理器,基于rpm,从源远程仓库下载rpm包安装,同时解决依赖关系,使用Python ...

  10. ubuntu 14.04升级PHP5.5.9 到5.6

    升级的步骤:参考https://www.digitalocean.com/community/questions/how-to-upgrade-from-php-v-5-5-9-to-v-5-6 su ...