亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C# WORD操作實現代碼

2020-01-24 03:46:37
字體:
來源:轉載
供稿:網友
1.先通過程序生成報表樣式的HTML頁面,然后修改HTML頁面的后綴名為DOC。
2.定制WORD文檔的模板文件,在C#中操作WORD模板,生成新的WORD文檔。
第一方案簡單,只需要改動文件的擴展名就行了,但是也存在了一些問題,譬如生成的WORD文檔樣式的丟失。這樣對于客戶來說可能是一個無法通過的方案。第二方案比較復雜,需要調用OFFICE的WORD組件通過C#來操作WORD,進而生成WORD。此方法類似于我們在c#中的后臺拼接數據。雖然麻煩,但是能夠靈活定制,只不過是操作WORD對象而已。
經過再三考慮:決定用第二種方法來生成WORD報告文檔。
通過自己的實踐,這個需求總算是搞定了,在實際開發的過程中,遇到了這樣那樣的問題,還好,通過不斷的查找網絡資源,結合實際開發中的情況,問題都得到了解決?,F將本人在開發過程中的一些理解與經驗總結一下:
在VS2008平臺下,引用.net-Microsoft.Office.Interop.Word.12,這樣就可以在程序用操作WORD對象了。
通過簡單執行,報了80070005錯誤,這個錯誤是因為權限不夠,需要在DCOM配置中更改.net和IIS用戶的操作權限,具體修改過程如下: 解決方法一:
1.控制面板-》管理工具-》組件服務-》計算機-》我的電腦-》DCom配置-》找到Microsoft Word文檔之后,單擊屬性打開此應 用程序的屬性對話框。
2.單擊標識選項卡,然后選擇交互式用戶。
3.單擊"安全"選項卡,分別在"啟動和激活權限"和"訪問權限"組中選中"自定義",然后自定義->編輯->添加ASP.NET賬戶和IUSER_計算機 名。
4. 確保允許每個用戶訪問,然后單擊確定。
5. 單擊確定關閉 DCOMCNFG。
如果上述方法不能解決問題,就應該是權限問題,請嘗試用下面的方法:
在web.config中使用身份模擬,在<system.web>節中加入 <identity impersonate="true" userName="你的用戶名 " password="密碼 "/>
</system.web>
解決了上述問題,開始考慮如何創建WORD模板文件,WORD的模板文件其實就是通過書簽來添加內容的。也就是通過在WORD文檔中創建書簽,然后在程序中獲取模板文件的所有書簽,通過給書簽賦值來進行文檔生成的。
在程序中的操作流程如下:
聲明WORD程序的對象 → 聲明一個WORD文檔對象 → 獲取當前的操作文檔對象 → 獲取文檔所有的書簽 → 將數據庫數據賦值到對應的書簽 → 將文檔另存為指定的文件夾下.
下面將針對農業植物測試報告來分析具體的代碼實現:
復制代碼 代碼如下:

//生成WORD程序對象和WORD文檔對象
Microsoft.Office.Interop.Word.Application appWord = new Application();
Microsoft.Office.Interop.Word.Document doc = new Document();
object oMissing = System.Reflection.Missing.Value;//這個是什么東西,我始終沒搞明白-_-
//打開模板文檔,并指定doc的文檔類型
object objTemplate = Server.MapPath(p_TemplatePath);
object objDocType = WdDocumentType.wdTypeDocument;
doc = (Document)appWord.Documents.Add(ref objTemplate, ref objFalse, ref objDocType, ref objTrue);
//獲取模板中所有的書簽
Bookmarks odf = doc.Bookmarks;
string[] testTableremarks = { "ApplyNo", "AuditingDate", "Auditor", "CheckDate", "Checker"};
string[] testTablevalues = { "ApplyNo", "AuditingDate", "Auditor", "CheckDate", "Checker",};
//循環所有的書簽,并給書簽賦值
for (int oIndex = 0; oIndex < testTableremarks.Length; oIndex++)
{
obDD_Name = WD + testTableremarks[oIndex];
doc.Bookmarks.get_Item(ref obDD_Name).Range.Text = p_TestReportTable.Rows[0][testTablevalues [oIndex]].ToString();//此處Range也是WORD中很重要的一個對象,就是當前操作參數所在的區域
}
//第四步 生成word,將當前的文檔對象另存為指定的路徑,然后關閉doc對象。關閉應用程序
object filename = Server.MapPath(p_SavePath) + "http://Testing_" + DateTime.Now.ToShortDateString() + ".doc";
object miss = System.Reflection.Missing.Value;
doc.SaveAs(ref filename, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss, ref miss);
object missingValue = Type.Missing;
object doNotSaveChanges = WdSaveOptions.wdDoNotSaveChanges;
doc.Close(ref doNotSaveChanges, ref missingValue, ref missingValue);
appWord.Application.Quit(ref miss, ref miss, ref miss);
doc = null;
appWord = null;
this.Hid_ShowMessage.Value = "生成成功!";

上述代碼就是一個通過模板文件生成WORD的過程。其實也就是一個替換書簽內容的過程。
在開發的過程中,有些數據是動態增加的,假如我要向一個表格中動態的添加幾行數據,就無法用替換書簽的方式來進行操作,需要通過程序在文檔頁面的表格中添加行。
向表格中添加行,有兩種操作形式:一種是在WORD模板中已經存在了一個表格。一種是我們在程序中直接添加一個表格對象。
第一種情況下,需要注意:在WORD模板中要操作的表格中,不能有縱向合并的單元格,不然程序無法獲取到當前要操作對象導致程序報錯.單元格的合并,我們可以在程序中控制。
第二種情況下就需要我們通過程序去直接添加表格了。
生成表格的代碼具體如下:
1.獲取文檔中已存在的表格:
Microsoft.Office.Interop.Word.Table characterTable = doc.Tables[2];//在document對象的集合操作中,起始點是從1開始,并不是從0開始的,此處需要注意。
2.在文檔中直接生成表格,首先要獲取插入表格的位置,然后添加表格對象:
object oEndOfDoc = "http://endofdoc";//WORD中預定義的書簽,還有很多,此處就不一一列舉。
object oMissing = System.Reflection.Missing.Value;
Range wrdRng = doc.Bookmarks.get_Item(ref oEndOfDoc).Range;//獲取當前文檔的末尾位置。
wrdRng.InsertAfter(" ");//插入一行,此處不能用 wrdRng.InsertAfter(""),如果用這個,就不能換行,我也不知道為什么。
復制代碼 代碼如下:

object oCollapseEnd = Microsoft.Office.Interop.Word.WdCollapseDirection.wdCollapseEnd;
object oPageBreak = Microsoft.Office.Interop.Word.WdBreakType.wdPageBreak;//分頁符
wrdRng.Collapse(ref oCollapseEnd);
wrdRng.InsertBreak(ref oPageBreak);//插入了一頁
wrdRng.Collapse(ref oCollapseEnd);
wrdRng.InsertAfter("圖片信息");
wrdRng.Font.Size = 20;//指定操作對象的文字大小
wrdRng.Font.Bold = 1;//指定操作對象的粗體:1為粗體,0為正常
wrdRng.ParagraphFormat.Alignment = WdParagraphAlignment.wdAlignParagraphCenter;//指定操作區域的文字布局:居中對齊
//上述代碼的意思是:找到當前的末尾位置,然后插入一個分頁符,相當于跳到了一個新頁,在這個新頁的頂端寫入文字“圖片信息”,并指定文字大小為20,粗體居中顯示。
wrdRng = doc.Bookmarks.get_Item(ref oEndOfDoc).Range;
wrdRng.InsertAfter(" ");
wrdRng = doc.Bookmarks.get_Item(ref oEndOfDoc).Range;
wrdRng.InsertParagraphAfter();//插入一個段落,在此段落上插入一個2行一列的表格。
Microsoft.Office.Interop.Word.Table newTable = doc.Tables.Add(wrdRng, 2, 1, ref oMissing, ref oMissing);

我們還可以對表格進行格式設置,此處我們就不在一一列舉。
3.下面我們分析一下對表格的單元格的操作:合并,拆分。這個就需要我們根據實際表格來進行操作:
//獲取具體的某個單元格(1,1),獲取第一行第一列的單元格
Cell cell = doc.Tables[1].Cell(1,1);
cell.Range.Text="Text";//指定當前單元格的內容為Text
在Table的操作中,添加新行:
object beforeRow = doc.Tables[1].Rows[2];//此行是先獲取到第二行
doc.Tables[1].Rows.Add(ref beforeRow);//效果類似于在WORD中此表格的第二行上進行【插入行】操作,插入的新行將會插入到當前行的上一行中,格式也是和此行一致的。
//合并單元格:感覺在此處合并單元格挺傻瓜的,你只需要指定你要合并的起始單元格和結束單元格,然后通過Merge操作就行了
Cell cell = doc.Tables[1].Cell(iRow, 2);//列合并
cell.Merge(doc.Tables[1].Cell(iRow, 6));
Cell cell1 = doc.Tables[1].Cell(iRow - 1, 1);//行合并
cell1.Merge(doc.Tables[1].Cell(iRow + 1, 1));
上述操作就是在此程序中用到的一些知識點,還有好多的東西需要去熟悉、理解。
另外,在程序的測試過程中發現,當執行一次文檔生成后,在資源管理器中始終有winword.exe進程殺不掉,目前的解決辦法是:直接殺進程,代碼如下:
復制代碼 代碼如下:

protected void killAllProcess() // 殺掉所有winword.exe進程
{
System.Diagnostics.Process[] myPs;
myPs = System.Diagnostics.Process.GetProcesses();
foreach (System.Diagnostics.Process p in myPs)
{
if (p.Id != 0)
{
string myS = "WINWORD.EXE" + p.ProcessName + " ID:" + p.Id.ToString();
try
{
if (p.Modules != null)
if (p.Modules.Count > 0)
{
System.Diagnostics.ProcessModule pm = p.Modules[0];
myS += "/n Modules[0].FileName:" + pm.FileName;
myS += "/n Modules[0].ModuleName:" + pm.ModuleName;
myS += "/n Modules[0].FileVersionInfo:/n" + pm.FileVersionInfo.ToString();
if (pm.ModuleName.ToLower() == "winword.exe")
p.Kill();
}
}
catch
{ }
finally
{

}
}
}
}

目前為止,一個WORD文檔就生成了。上述為我在這個程序開發中遇到的問題和解決方法,可能有好多地方都是考慮不全的,如果在程序開發中對WORD的操作有新的認識的話,歡迎和我溝通交流,彼此提高!
下邊是在網上一些比較好的摘抄:
創建新Word
復制代碼 代碼如下:

object oMissing = System.Reflection.Missing.Value;
Word._Application oWord;
Word._Document oDoc;
oWord = new Word.Application();
oWord.Visible = true;
oDoc = oWord.Documents.Add(ref oMissing, ref oMissing,
ref oMissing, ref oMissing);

打開文檔:
復制代碼 代碼如下:

object oMissing = System.Reflection.Missing.Value;
Word._Application oWord;
Word._Document oDoc;
oWord = new Word.Application();
oWord.Visible = true;
object fileName = @"E:CCCXCXXTestDoc.doc";
oDoc = oWord.Documents.Open(ref fileName,
ref oMissing, ref oMissing, ref oMissing, ref oMissing, ref oMissing,
ref oMissing, ref oMissing, ref oMissing, ref oMissing, ref oMissing,
ref oMissing, ref oMissing, ref oMissing, ref oMissing, ref oMissing);

導入模板
復制代碼 代碼如下:

object oMissing = System.Reflection.Missing.Value;
Word._Application oWord;
Word._Document oDoc;
oWord = new Word.Application();
oWord.Visible = true;
object fileName = @"E:XXXCCXTest.doc";
oDoc = oWord.Documents.Add(ref fileName, ref oMissing,
ref oMissing, ref oMissing);

.添加新表
復制代碼 代碼如下:

object oMissing = System.Reflection.Missing.Value;
Word._Application oWord;
Word._Document oDoc;
oWord = new Word.Application();
oWord.Visible = true;
oDoc = oWord.Documents.Add(ref oMissing, ref oMissing,
ref oMissing, ref oMissing);
object start = 0;
object end = 0;
Word.Range tableLocation = oDoc.Range(ref start, ref end);
oDoc.Tables.Add(tableLocation, 3, 4, ref oMissing, ref oMissing);

.表插入行
復制代碼 代碼如下:

object oMissing = System.Reflection.Missing.Value;
Word._Application oWord;
Word._Document oDoc;
oWord = new Word.Application();
oWord.Visible = true;
oDoc = oWord.Documents.Add(ref oMissing, ref oMissing,
ref oMissing, ref oMissing);
object start = 0;
object end = 0;
Word.Range tableLocation = oDoc.Range(ref start, ref end);
oDoc.Tables.Add(tableLocation, 3, 4, ref oMissing, ref oMissing);
Word.Table newTable = oDoc.Tables[1];
object beforeRow = newTable.Rows[1];
newTable.Rows.Add(ref beforeRow);

.單元格合并
復制代碼 代碼如下:

object oMissing = System.Reflection.Missing.Value;
Word._Application oWord;
Word._Document oDoc;
oWord = new Word.Application();
oWord.Visible = true;
oDoc = oWord.Documents.Add(ref oMissing, ref oMissing,
ref oMissing, ref oMissing);
object start = 0;
object end = 0;
Word.Range tableLocation = oDoc.Range(ref start, ref end);
oDoc.Tables.Add(tableLocation, 3, 4, ref oMissing, ref oMissing);
Word.Table newTable = oDoc.Tables[1];
object beforeRow = newTable.Rows[1];
newTable.Rows.Add(ref beforeRow);
Word.Cell cell = newTable.Cell(1, 1);
cell.Merge(newTable.Cell(1, 2));

.單元格分離
復制代碼 代碼如下:

object oMissing = System.Reflection.Missing.Value;
Word._Application oWord;
Word._Document oDoc;
oWord = new Word.Application();
oWord.Visible = true;
oDoc = oWord.Documents.Add( oMissing,
ref oMissing, ref oMissing);
object start = 0;
object end = 0;
Word.Range tableLocation = oDoc.Range(ref start, ref end);
oDoc.Tables.Add(tableLocation, 3, 4, ref oMissing, ref oMissing);
Word.Table newTable = oDoc.Tables[1];
object beforeRow = newTable.Rows[1];
newTable.Rows.Add(ref beforeRow);
Word.Cell cell = newTable.Cell(1, 1);
cell.Merge(newTable.Cell(1, 2));
object Rownum = 2;
object Columnnum = 2;
cell.Split(ref Rownum, ref Columnnum);

通過段落控制插入
復制代碼 代碼如下:

object oMissing = System.Reflection.Missing.Value;
object oEndOfDoc = "/endofdoc"; /**//* endofdoc is a predefined bookmark */
//Start Word and create a new document.
Word._Application oWord;
Word._Document oDoc;
oWord = new Word.Application();
oWord.Visible = true;
oDoc = oWord.Documents.Add(ref oMissing, ref oMissing,
ref oMissing, ref oMissing);
//Insert a paragraph at the beginning of the document.
Word.Paragraph oPara1;
oPara1 = oDoc.Content.Paragraphs.Add(ref oMissing);
oPara1.Range.Text = "Heading 1";
oPara1.Range.Font.Bold = 1;
oPara1.Format.SpaceAfter = 24; //24 pt spacing after paragraph.
oPara1.Range.InsertParagraphAfter();
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
不卡av电影在线观看| 国产精品国产自产拍高清av水多| 日韩精品免费在线播放| 国产精品香蕉国产| 欧美一级在线播放| www.亚洲天堂| 日韩精品999| 亚洲免费伊人电影在线观看av| 成人国产精品av| 亚洲欧洲自拍偷拍| 久久偷看各类女兵18女厕嘘嘘| 日韩欧美精品免费在线| 深夜福利国产精品| 色综合视频一区中文字幕| 久久精品国产清自在天天线| 最新69国产成人精品视频免费| 国产精品成人va在线观看| 国产精品免费视频xxxx| 日本成人在线视频网址| 国产91精品不卡视频| 日日摸夜夜添一区| 亚洲一区av在线播放| 91综合免费在线| 在线看欧美日韩| 久热精品视频在线| 日韩在线观看高清| 国产精品日韩专区| 日韩视频免费中文字幕| 欧美激情视频网| 国产精品亚洲美女av网站| 911国产网站尤物在线观看| 最新的欧美黄色| 欧美激情欧美激情在线五月| 综合av色偷偷网| 欧美在线视频一区二区| 日韩三级影视基地| 国产精品久久久久av免费| 成人久久久久久久| 国产成人一区二区三区小说| 97久久久免费福利网址| 国产精品久久久久久久久久ktv| 不卡伊人av在线播放| 欧美另类极品videosbestfree| 最近2019年手机中文字幕| 一区二区三区无码高清视频| 久久视频这里只有精品| 日韩欧美亚洲范冰冰与中字| 久久天天躁狠狠躁夜夜av| 美女撒尿一区二区三区| 欧美福利小视频| 亚洲精选在线观看| 欧美大片网站在线观看| 国产91在线视频| 欧美大码xxxx| 欧美日韩成人在线播放| 亚洲欧洲日产国码av系列天堂| 日韩小视频在线| 韩国精品久久久999| 91精品国产综合久久久久久蜜臀| 亚洲字幕在线观看| zzijzzij亚洲日本成熟少妇| 国产精品一区二区三区久久| 91久久久久久| 欧美最猛性xxxxx(亚洲精品)| 热久久美女精品天天吊色| 一区二区三区天堂av| 久久99国产精品自在自在app| 国产女人18毛片水18精品| 日韩国产激情在线| 欧美极品美女电影一区| 国产成人午夜视频网址| 国产美女精品免费电影| 中文字幕av一区中文字幕天堂| 国产精品旅馆在线| 成人h片在线播放免费网站| 一本色道久久88亚洲综合88| 国产亚洲精品成人av久久ww| 欧美大片在线影院| 日韩在线免费视频观看| 国产精品吊钟奶在线| 78m国产成人精品视频| 超碰日本道色综合久久综合| 欧美激情videoshd| 精品成人国产在线观看男人呻吟| 91系列在线播放| 日韩有码在线播放| 国产一区二区三区久久精品| 日韩精品视频在线| 亚洲高清av在线| 国产精品久久激情| 日韩精品久久久久久福利| 欧美xxxwww| 日韩av电影在线免费播放| 国产一区二区在线免费视频| 97精品国产97久久久久久春色| 国产999在线观看| 日韩精品中文字幕视频在线| 国模gogo一区二区大胆私拍| 亚洲精选在线观看| 亚洲国产精品99| www.日韩.com| 中文字幕亚洲色图| 一区二区三区回区在观看免费视频| 日韩精品www| 欧美高清视频在线播放| 欧美黄色小视频| 国产精品高潮呻吟视频| 精品无人区乱码1区2区3区在线| 国产亚洲成av人片在线观看桃| 日韩欧美在线视频免费观看| 久久99国产综合精品女同| 国产精品久久国产精品99gif| 久久久免费电影| 欧美激情视频三区| 日韩网站免费观看高清| 久久久人成影片一区二区三区观看| www.亚洲男人天堂| 日本高清+成人网在线观看| 国产欧美在线视频| 精品视频久久久久久| 亚洲精品一区av在线播放| 精品国内亚洲在观看18黄| 日韩精品视频在线观看免费| 欧美成人全部免费| 欧美老少做受xxxx高潮| 色妞在线综合亚洲欧美| 热99在线视频| 欧洲亚洲免费在线| 亚洲黄色免费三级| 亚洲在线第一页| 国产性猛交xxxx免费看久久| 欧美日本啪啪无遮挡网站| 中文字幕av一区中文字幕天堂| 欧美一区在线直播| 国产精品揄拍一区二区| 欧美乱妇40p| 国产成人在线亚洲欧美| 91视频-88av| 欧美日韩国产精品一区二区三区四区| 国产精品18久久久久久首页狼| 亚洲精品在线91| 亚洲欧美精品伊人久久| 久久99视频精品| 亚洲丁香久久久| 日韩精品免费在线观看| 91国产精品视频在线| 精品福利樱桃av导航| 91社影院在线观看| 国产成人在线视频| 大桥未久av一区二区三区| 亚洲欧美成人在线| 精品久久久久久亚洲精品| 日韩女优在线播放| 日韩欧美综合在线视频| 亚洲色在线视频| 亚洲国产福利在线| 国产在线a不卡| 国产91露脸中文字幕在线| 亚洲精品在线视频| 国内精品久久久久伊人av| 亚洲女人被黑人巨大进入al| 亚洲区免费影片| 色婷婷av一区二区三区久久| 8x拔播拔播x8国产精品|