使用点聚 weboffice 以及vsto、 web service 实现word 的自动化文档处理
开发环境的搭建:
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 的自动化文档处理的更多相关文章
- 微软office web apps 服务器搭建之在线文档预览
案例:http://owa.linbsoft.com/op/generate.aspx# 文档地址:http://demo.linbsoft.com/CourseFile/201407/2014070 ...
- ASP.NET Web API编程——构建api帮助文档
1 概要 创建ASP.NET Web Api 时模板自带Help Pages框架. 2 问题 1)使用VS创建Web Api项目时,模板将Help Pages框架自动集成到其中,使得Web Api项目 ...
- ASP.NET Web API从注释生成帮助文档
默认情况下,ASP.NET Web API不从Controller的注释中生成帮助文档.如果要将注释作为Web API帮助文档的一部分,比如在帮助文档的Description栏目中显示方法注释中的su ...
- 微软office web apps 服务器搭建之在线文档预览(一)
office web apps安装 系统要求为Windows Server 2012, 注意:转换文档需要两台服务器,一台为转换server,另外一台为域控server.(至于为什么要两台,这个请自行 ...
- 微软office web apps 服务器搭建之在线文档预览(二)
上一篇文章已经介绍了整个安装过程了.只要在浏览器中输入文档转换server的ip,会自动跳转,出现如下页面. 那么就可以实现本地文档预览了,你可以试试.(注意:是本地哦,路径不要写错,类似“\\fil ...
- Web Api使用Swagger提供在线文档
1.添加Swashbuckle引用 2.生成XML文件 3.添加XML解析,在接口添加注释信息 4.运行项目输入地址 http://localhost:58254/swagger
- DoNetCore Web Api 采用Swagger进行接口文档管理
第一步:创建API项目 步骤这里不说明 第二步:就是Nuget 包, 两种方式:1.工具->Nuget管理->程序包管理控制台 Install-Package Swashbuckle.As ...
- Web Service学习小结(概念性回忆)-希望你们会喜欢
Web Service的出现带来了很多系统工程直接相互的调用.无疑让代码的隐藏得到了好的封装. Web Service 它的主要的组成要素: SOAP:(Simple Object Access P ...
- 在ASP.NET Core Web API上使用Swagger提供API文档
我在开发自己的博客系统(http://daxnet.me)时,给自己的RESTful服务增加了基于Swagger的API文档功能.当设置IISExpress的默认启动路由到Swagger的API文档页 ...
随机推荐
- Confluence 6 配置用户目录
一个用户目录是你存储你的用户和用户组信息的地方.用户信息包括有用户的全名,用户名,密码和电子邮件地址以及其他的一些个人信息. 用户组包括有用户组名字,属于这个用户组的用户和有可能属于这个用户组的另一个 ...
- hdu3374 kmp+最小表示法
Give you a string with length N, you can generate N strings by left shifts. For example let consider ...
- python 小练习 10
给你一个十进制数a,将它转换成b进制数,如果b>10,用大写字母表示(10用A表示,等等) a为32位整数,2 <= b <= 16 如a=3,b = 2, 则输出11 AC: di ...
- M爷的线段树
M爷的线段树 - BUCTOJ 3305 一个长度为n的数列A.修改m次,每次给区间[L,R]中的每一个数加X.查询k次,每次查询第i个元素的值并输出.1<=n<=1e5 ,1<=m ...
- XML文档的创建
右键项目,添加,新建项,XML文件 XML文件的第一行有一个标题,标题描述了这个XML文件的版本和编码 XML文件必须有根节点且只能有一个根节点,如<Books></Books> ...
- SQL优化(SQL TUNING)可大幅提升性能的实战技巧之一——让计划沿着索引跑
我们进行SQL优化时,经常会碰到对大量数据集进行排序,然后从排序后的集合取前部分结果的需求,这种情况下,当我们按照常规思路去写SQL时,系统会先读取过滤获得所有集合,然后进行排序,再从排序结果取出极少 ...
- 这可能是最简明扼要的 js事件冒泡机制+阻止默认事件 讲解了
哎 js事件冒泡机制和阻止冒泡 阻止默认行为好像永远也整不清楚,记了忘 忘了记...醉了 这篇文章写完以后下次再忘记 就呼自己一巴掌,忘一次一巴掌 首先要明白两个概念——事件和事件流 事件指的是用户或 ...
- PHP:第一章——PHP中的算术运算符/递增、递减运算符/赋值运算符
算术运算符 //$a=10; $b=5; //取反: //echo -$a;//输出:-10: //加法: //echo $a+$b;//输出:15 //减法: //echo $a-$b;//输出:5 ...
- PHP:第一章——php中的变量001 /普通赋值/引用赋值/php变量的检查与销毁
<?php //php中的变量: //php中的变量用一个美元符$后面紧跟着变量名来表示,变量名是区分大小写的. //有效的变量只能是字母或者下划线开头,后面跟任意数量的字母.数字.或者下划线. ...
- Myeclipse快键键
------------------------------------MyEclipse 快捷键1(CTRL)-------------------------------------Ctrl+1 ...