开发环境的搭建:

1.visual studio 2010

2. 点聚web office

开发步骤

1. 创建word vsto 项目

比较简单

1. 添加任务窗格

页面如下:

代码如下:

1. 使用web service 获取数据

因为开发测试返回的数据时xml 所以进行了datatable的转换

partial class ActionsPaneControl1 : UserControl
    {
        DataTable dt = new DataTable();
        DataTable dm = new DataTable();
        ufsea.SEAOrganizationService service = new ufsea.SEAOrganizationService();
        public ActionsPaneControl1()
        {
            InitializeComponent();
        }

private void button1_Click(object sender, EventArgs e)
        {
            dataGridView1.AutoGenerateColumns = false;
            dt = CusdbCommon.XMLHelper.XmlDeserializeUnicode(service.GetCorporationListOfGuFen());
            dataGridView1.DataSource = dt;

}

private void button2_Click(object sender, EventArgs e)
        {
            Globals.ThisDocument.bookmark1.Text = "this is a dmeo";
            Globals.ThisDocument.bookmark2.Text = "first app";

}

private void button3_Click(object sender, EventArgs e)
        {
            Globals.ThisDocument.bookmark2.Text = textBox3.Text;
        }

private void button4_Click(object sender, EventArgs e)
        {
            dm = dt.Clone();
            foreach (DataRow item in dt.Select("CorpName like '" + textBox2.Text + "%'"))
            {
             
                dm.ImportRow(item);
             
            }
            dataGridView1.DataSource = dm;
        }
       
        private void button5_Click(object sender, EventArgs e)
        {
            DataGridViewSelectedRowCollection selectlist=dataGridView1.SelectedRows;
            foreach (DataGridViewRow item in selectlist)
            {
                int rowcount = Globals.ThisDocument.Tables[1].Rows.Count;
                int colcount = Globals.ThisDocument.Tables[1].Columns.Count;
                 Microsoft.Office.Interop.Word.Table tbl= Globals.ThisDocument.Tables[1];
                 tbl.Rows.Add();                 int rowcount1 = Globals.ThisDocument.Tables[1].Rows.Count;
                int colcount1 = Globals.ThisDocument.Tables[1].Columns.Count;
                tbl.Cell(rowcount1, 1).Range.Text = item.Cells[1].Value.ToString();
                tbl.Cell(rowcount1, 2).Range.Text = item.Cells[2].Value.ToString();
                tbl.Cell(rowcount1, 3).Range.Text = item.Cells[3].Value.ToString(); 
            }
        }
    }

数据转换的xmlhelper 如下:

public class XMLHelper
    {
        public XMLHelper()
        {
            //
            // TODO: 在此处添加构造函数逻辑
            //
        }

public static string XMLError(string title)
        {
            return "<Customer><error>" + title + "</error></Customer>";
        }
        public static string XMLSucess(string title)
        {
            return "<Customer><success>" + title + "</success></Customer>";
        }
        public static string XMLRet(string title)
        {
            return "<ret>" + title + "</ret>";
        }
        public static string XMLHeader
        {
            get
            {
                return "<Customer>";
            }
        }
        public static string XMLFooter
        {
            get
            {
                return "</Customer>";
            }
        }

public static string getvalue(string str, string reg)
        {
            string regexString = @"<" + reg + ">([\\w\\W]*?)</" + reg + ">";
            string val = "";
            string[] getUrls = getElements(str, regexString, "$1");
            if (getUrls.Length != 0)
            {
                val = getUrls[0];
            }
            return val;
        }

private static string[] getElements(string m_bookHTML, string strRegexString, string strReplaceText)
        {
            string[] ArrBlock = HtmlRegexURL(strRegexString, strReplaceText, m_bookHTML);
            return ArrBlock;
        }

private static string[] HtmlRegexURL(string strRegexString, string replaceText, string strNeedDoHtml)
        {
            string[] returnarray;
            if (strNeedDoHtml == null)
            {
                returnarray = null;
            }
            else
            {
                Regex matchsRegex = new Regex(strRegexString, RegexOptions.None);
                int[] m_num = matchsRegex.GetGroupNumbers();
                MatchCollection matchsFound;
                matchsFound = matchsRegex.Matches(strNeedDoHtml);
                int returnnum = matchsFound.Count;
                returnarray = new string[returnnum];
                int i = 0;
                foreach (Match matchMade in matchsFound)
                {
                    if (replaceText.Length > 0)
                    {
                        returnarray[i] = matchMade.Result(replaceText);
                    }
                    else
                    {
                        returnarray[i] = matchMade.Value;
                    }
                    i++;
                }
            }
            return returnarray;
        }

#region 对象的序列化和反序列化(Xml格式) XmlSerialize/XmlDeserialize
        /*
            例子:
            String ReturnValue=XMLHelper.XmlSerialize(arrExample,typeof([ClassName]))
         */
        public static string XmlSerialize(object obj, params Type[] extra)
        {
            XmlSerializer ser = new XmlSerializer(obj.GetType(), extra);
            System.IO.MemoryStream mem = new MemoryStream();
            XmlTextWriter writer = new XmlTextWriter(mem, System.Text.Encoding.Default);
            ser.Serialize(writer, obj);
            string strtmp = Encoding.Default.GetString(mem.ToArray());
            return strtmp;
        }

/*
            例子:
            ArrayList arrExample = (ArrayList)XMLHelper.XmlDeserialize(value, typeof(ArrayList), typeof([ClassName]));
         */
        public static object XmlDeserialize(string xml, Type type,params Type[] extra)
        {
            XmlSerializer serializer = new XmlSerializer(type,extra);
            System.IO.MemoryStream mem = new MemoryStream(Encoding.Default.GetBytes(xml));
            return serializer.Deserialize(mem);
        }

public static string XmlSerialize(DataTable dt, string tableName)
        {
            dt.TableName = tableName;
            System.Text.StringBuilder strbuilder = new System.Text.StringBuilder();
            StringWriter writer = new StringWriter(strbuilder);
            dt.WriteXml(writer, System.Data.XmlWriteMode.IgnoreSchema);
            return strbuilder.ToString();
        }

public static DataTable XmlDeserialize(string xml)
        {
            DataSet ds = new DataSet();
            DataTable dt = new DataTable();
            MemoryStream mem = new MemoryStream(Encoding.Default.GetBytes(xml));
            ds.ReadXml(mem);
            if (ds.Tables.Count > 0)
                dt = ds.Tables[0];
            return dt;
        }
        public static DataTable XmlDeserializeUnicode(string xml)
        {
            DataSet ds = new DataSet();
            DataTable dt = new DataTable();
            MemoryStream mem = new MemoryStream(Encoding.UTF8.GetBytes(xml));
            ds.ReadXml(mem);
            if (ds.Tables.Count > 0)
                dt = ds.Tables[0];
            return dt;
        }
        #endregion
    }

2. word 页面的表格显示

页面如下:

3. 使用word 进行的测试

加载数据页面:

动态添加表格数据页面

4. 使用点聚web office 进行显示操作

点聚web office的使用大家百度一下就知道了。

我只贴出代码意识使用的方式:

使用WebOffice常用接口调用 文件夹中的例子即可

实际进行部署的时候我们一般选择使用安装包,我只是为了进行测试,这种方式在实际的环境中运行是有问题的

使用IE 进行测试的页面:与上面的类似。

使用点聚 weboffice 以及vsto、 web service 实现word 的自动化文档处理的更多相关文章

  1. 微软office web apps 服务器搭建之在线文档预览

    案例:http://owa.linbsoft.com/op/generate.aspx# 文档地址:http://demo.linbsoft.com/CourseFile/201407/2014070 ...

  2. ASP.NET Web API编程——构建api帮助文档

    1 概要 创建ASP.NET Web Api 时模板自带Help Pages框架. 2 问题 1)使用VS创建Web Api项目时,模板将Help Pages框架自动集成到其中,使得Web Api项目 ...

  3. ASP.NET Web API从注释生成帮助文档

    默认情况下,ASP.NET Web API不从Controller的注释中生成帮助文档.如果要将注释作为Web API帮助文档的一部分,比如在帮助文档的Description栏目中显示方法注释中的su ...

  4. 微软office web apps 服务器搭建之在线文档预览(一)

    office web apps安装 系统要求为Windows Server 2012, 注意:转换文档需要两台服务器,一台为转换server,另外一台为域控server.(至于为什么要两台,这个请自行 ...

  5. 微软office web apps 服务器搭建之在线文档预览(二)

    上一篇文章已经介绍了整个安装过程了.只要在浏览器中输入文档转换server的ip,会自动跳转,出现如下页面. 那么就可以实现本地文档预览了,你可以试试.(注意:是本地哦,路径不要写错,类似“\\fil ...

  6. Web Api使用Swagger提供在线文档

    1.添加Swashbuckle引用 2.生成XML文件 3.添加XML解析,在接口添加注释信息 4.运行项目输入地址   http://localhost:58254/swagger

  7. DoNetCore Web Api 采用Swagger进行接口文档管理

    第一步:创建API项目 步骤这里不说明 第二步:就是Nuget 包, 两种方式:1.工具->Nuget管理->程序包管理控制台 Install-Package Swashbuckle.As ...

  8. Web Service学习小结(概念性回忆)-希望你们会喜欢

    Web Service的出现带来了很多系统工程直接相互的调用.无疑让代码的隐藏得到了好的封装. Web  Service 它的主要的组成要素: SOAP:(Simple Object Access P ...

  9. 在ASP.NET Core Web API上使用Swagger提供API文档

    我在开发自己的博客系统(http://daxnet.me)时,给自己的RESTful服务增加了基于Swagger的API文档功能.当设置IISExpress的默认启动路由到Swagger的API文档页 ...

随机推荐

  1. javaScript 的 map() reduce() foreach() filter()

    map(映射), reduce(规约), forEach(遍历), filter(过滤),它们都是高阶函数,都是以传入不同的函数来以不同的方式操作数组元.ie都不支持 一.map方法 *概述 map( ...

  2. Android之ToolBar和自定义ToolBar实现沉浸式状态栏

    沉浸式状态栏确切的说应该叫做透明状态栏.一般情况下,状态栏的底色都为黑色,而沉浸式状态栏则是把状态栏设置为透明或者半透明. 沉浸式状态栏是从android Kitkat(Android 4.4)开始出 ...

  3. AIM Tech Round 3 (Div. 1) (构造,树形dp,费用流,概率dp)

    B. Recover the String 大意: 求构造01字符串使得子序列00,01,10,11的个数恰好为$a_{00},a_{01},a_{10},a_{11}$ 挺简单的构造, 注意到可以通 ...

  4. javaScript数组的三种属性—数组索引、数组内置属性、数组自定义属性

    JS数组也是一种对象. 我们用JavaScript处理的所有东西,都可以视为是一种对象. JavaScript中有两种数据类型,基本类型数对象类型,但是基本类型基本都是包括在对象类型之中的. 数组.函 ...

  5. python-day34--并发编程之多线程

    理论部分 一.什么是线程: 1.线程:一条流水线的工作过程  2.一个进程里至少有一个线程,这个线程叫主线程 进程里真正干活的就是线程 3.进程只是用来把资源集中到一起(进程只是一个资源单位,或者说资 ...

  6. python 小练习 11

    桌子上有一堆数量不超过20的果子,每个果子的重量都是不超过20的正整数,全部记录在列表 L 里面.小明和小红决定平分它们,但是由于他们都太自私,没有人愿意对方比自己分得的总重量更多.而果子又不能切开, ...

  7. bind出现Address already in use解决方法

    在socket函数和bind函数之间加入一段代码: // 建立服务器端socket if((server_sockfd = socket(AF_INET, SOCK_STREAM, 0))<0) ...

  8. ThreadPoolExecutor类

    首先分析内部类:ThreadPoolExecutor$Worker //Worker对线程和任务做了一个封装,同时它又实现了Runnable接口, //所以Worker类的线程跑的是自身的run方法 ...

  9. vue-cli的安装及使用

    一.    node 和npm 1.在安装vue-cli前,要确认自己的电脑是否安装了node和npm 2.查询版本如下(vue脚手架支持node@4.xx以上) node -v    查询node版 ...

  10. pythoon 学习资源

    https://github.com/zhu327/forum http://www.ziqiangxuetang.com/django/django-tutorial.html