分享
 
 
 

利用.net替换Word的内容(从数据库中取数据来替换word里面的书签)

王朝asp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

我在现在的项目中,用户需要打印办文单,一开始做的时候,就用是用表格,按照他们的格式划了一个,可是,打出来的东西总是和他们自己的不一样,(一句话,不好看),我也头疼一阶段没什么好的办法,后来想,干脆把他们word模板拿过来,自己来替换.刚开始的时候,不知道怎么做问了,google找了,但没有一样的满意的.后来还是在msdn上找了一点点,然后请教了同事.在总算搞定.效果还不错.

整个过程是这样的:(本人用的是asp.net+C#)

1.

首先需要将word的dll引入进来,如果装了word的话,会在他的安装目录下面有一个MSWORD9.OLB文件(通过添加引用即可)这里需要注意的是上面这个文件,可能会因为office的版本不一样,文件名有所不同,而且在下面的open和save方法的参数也会因为版本的不同而不同,office2003中的open方面的参数好象是16个,而2000里的参数大概只有12个,调用的时候一定要注意

2.

要在webconfig文件里面加上一句: <identity impersonate="true"/>主要是模拟身份的吧,如果不加的话,程序运行的时候会报出拒绝访问的错误的.(而且你需要预先做好一个带书签的word模板)

3.

新建立一个也面,在面上部加如using Word;

下面就是具体的函数了:(我这里的函数没有整理过,可能有些没用)

打开文件:

private Word.Document OpenDoc(string strDocPath,ref Word.Application WordApp,int flag)

{

if (!File.Exists(strDocPath))

return null;

object fileName = (object)strDocPath;

object isVisible = missing;

object readOnly = missing;

//Make word visible, so you can see what's happening

WordApp.Visible = false;

//通过open创建一个Word.Document的实例

Word.Document doc = null;

try

{

//doc = WordApp.Documents.Open(ref fileName, ref missing,ref readOnly, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref isVisible,ref missing,ref missing,ref missing,ref missing);

doc = WordApp.Documents.Open(ref fileName, ref missing,ref missing,ref missing, ref missing, ref missing, ref missing, ref missing, ref missing,ref missing, ref missing, ref missing);

//if (flag == 1)

//ListStyle(doc);

return doc;

}

catch(Exception Ex)

{

throw new Exception(Ex.Message);

return null;

}

}

替换模板内容:

string strWordTemplate = Server.MapPath("../test/办文单.doc");//这里是你的模板文件

Word.Application WordApp = new Word.ApplicationClass();// 定义一个Word.Application 对象

Word.Document doc = OpenDoc(strWordTemplate,ref WordApp,1);//定义一个Word.Document 对象

try

{

//下面是从数据库取数据,不好意思这个代码有点烂

DataTable TempTable=this.CreateTable("Select * from Workflow_BW where AppID="+Convert.ToInt32(AppID)+" and ContentID="+Convert.ToInt32(ContentID));

if(TempTable.Rows.Count>0)

{

string TempTime=TempTable.Rows[0]["SWTime"].ToString().Trim();

int Pos=TempTime.IndexOf(" ");

string All=TempTime.Substring(0,Pos);

int Pre=All.IndexOf("-");

int Next=All.LastIndexOf("-");

string Year=All.Substring(0,Pre).Trim();

string Month=All.Substring(Pre+1,Next-Pre-1).Trim();

string Day=All.Substring(Next+1,All.Length-Next-1).Trim();

foreach(Word.Bookmark BM in doc.Bookmarks)//这是最关键的地方:对文档的所有书签进行便利匹配

{

switch(BM.Name)

{

case "Advice"://替换Advice书签的内容,其他一样

BM.Select();

BM.Range.Text=this.CreateTable("Select Advice from Workflow_Advice where AppID="+Convert.ToInt32(AppID)+" and ContentID="+Convert.ToInt32(this.ContentID)+" and StepID=1").Rows[0]["Advice"].ToString().Trim();

break;

case "Day":

BM.Select();

BM.Range.Text=Day;

break;

case "LWDW":

BM.Select();

BM.Range.Text=TempTable.Rows[0]["LWDW"].ToString().Trim();

break;

case "LWH":

BM.Select();

BM.Range.Text=TempTable.Rows[0]["SWH"].ToString().Trim();

break;

case "Month":

BM.Select();

BM.Range.Text= Month;

break;

case "NowYear":

BM.Select();

BM.Range.Text=Year;

break;

case "Subject":

BM.Select();

BM.Range.Text=TempTable.Rows[0]["Subject"].ToString().Trim();

break;

case "SWH":

BM.Select();

BM.Range.Text=TempTable.Rows[0]["LSH"].ToString().Trim().Substring(4,TempTable.Rows[0]["LSH"].ToString().Trim().Length-4);

break;

}

}

}

object fn = (object)Server.MapPath("../test/temp.doc");

doc.SaveAs(ref fn, ref missing,ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing,ref missing, ref missing);//这里是另存为一个一个文件

Response.Redirect("../test/temp.doc");//直接打开用ie打开另存的文件,然后可直接调用ie里的打印功能

//doc.SaveAs(ref fn, ref missing,ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing,ref missing, ref missing, ref missing,ref missing,ref missing,ref missing,ref missing);

}

catch(Exception err)

{

this.tbXml.Text = err.ToString();

}

finally

{

doc.Close(ref missing,ref missing,ref missing);

WordApp.Quit(ref missing,ref missing,ref missing);

WordApp = null;

}

}

这里面一个最主要的问题, doc.Close(ref missing,ref missing,ref missing);

WordApp.Quit(ref missing,ref missing,ref missing);

WordApp = null;

这个代码好象不起作用,每次关闭打印的时候都会抱word错误,而且进程里面winword.exe也没关,不知道怎么回事.

关于word里面的一些对象如:Application document Selection Range BookMark对象,本人也不是很熟悉,请参考MSDN上的帮助,那里面讲的很详细.希望对大家有所帮助

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有