我主要是將現有的模板填入數據保存文檔即可。主題是TABLE填值,檢索TABLE主要是通過下標,如:
WordDoc.Tables[6]
其中WordDoc的類型是Word.Document,就是當前操作的word文檔,上面的代碼是獲取當前文檔中的第六個表格,這里要注意一下,
我們慣性會認為是第七個表格,但這就是微軟的不同,沒有采用數組索引的方式,如果當初數組也這么設計,下標從1開始,我們學習的時候不知道省多少事。
開發過程中遇到了一個小難題就是合并單元格(縱向),沒有設計橫向的合并,現將合并的代碼貼出來備用:

/**//// <summary>
/// 縱向單元格合并
/// 說明:如合并了第一行第一列和第二行第一列兩個單元格,則單元格cell(2, 1)已經不存在,繼續操作會有異常,
/// 只有通過cell(1, 1)來獲取合并后的單元格
/// /<summary>
/// <param name="table"></param>
/// <param name="startRowIndex"></param>
/// <param name="columnIndex"></param>
private static void verticalCellMerge(Word.Table table, int startRowIndex, int columnIndex)


{
string previousText = table.Cell(startRowIndex++, columnIndex).Range.Text; // 保存對比文字
int previousRowIndex = startRowIndex - 1; // 因剛已經+1了,所以再減回去
for (int i = startRowIndex; i <= table.Rows.Count; ++i) // 遍歷所有行的columnIndex列,發現相同的合并,從起始行的下一行開始對比

{
string currentText = table.Cell(i, columnIndex).Range.Text;
if (previousText.Equals(currentText))

{
table.Cell(previousRowIndex, columnIndex).Merge(table.Cell(i, columnIndex)); // 合并先前單元格和當前單元格
table.Cell(previousRowIndex, columnIndex).Range.Text = currentText; // 因為合并后并沒有將單元格內容去除,需要手動修改
table.Cell(previousRowIndex, columnIndex).Select();
WordApp.Selection.ParagraphFormat.Alignment = WdParagraphAlignment.wdAlignParagraphCenter; // 水平居中顯示
table.Cell(previousRowIndex, columnIndex).VerticalAlignment = Word.WdCellVerticalAlignment.wdCellAlignVerticalCenter; // 垂直居中
}
else

{
previousText = currentText; // 將對比文字替換為當前的內容
previousRowIndex = i; // 檢索到不同的內容,將當前行下標置為先前行下標,用于合并
}
}
}


/**//// <summary>
/// 橫向單元格合并
/// 注意:在合并單元格后必須將縱列數減去1
/// 如第一行第一列和第一行第二列合并后,原第一行第三列將變成第一行第二列,這就是在合并后i不加1的原因
/// </summary>
/// <param name="WordApp"></param>
/// <param name="table"></param>
/// <param name="startColumnIndex"></param>
/// <param name="rowIndex"></param>
private static void horizontalCellMerge(Word.Application WordApp, Word.Table table, int startColumnIndex, int rowIndex)


{
string previousText = table.Cell(rowIndex, startColumnIndex).Range.Text; // 保存對比文字
int previousColumnIndex = startColumnIndex++; // 保存先前對比列下標
int colCount = table.Columns.Count;
for (int i = startColumnIndex; i <= colCount;) // 遍歷所有行的columnIndex列,發現相同的合并,從起始行的下一行開始對比

{
string currentText = table.Cell(rowIndex, i).Range.Text;
if (previousText.Equals(currentText))

{
table.Cell(rowIndex, previousColumnIndex).Merge(table.Cell(rowIndex, i)); // 合并先前單元格和當前單元格
table.Cell(rowIndex, previousColumnIndex).Range.Text = currentText; // 因為合并后并沒有將單元格內容去除,需要手動修改
table.Cell(rowIndex, previousColumnIndex).Select();
WordApp.Selection.ParagraphFormat.Alignment = WdParagraphAlignment.wdAlignParagraphCenter; // 水平居中顯示
table.Cell(rowIndex, previousColumnIndex).VerticalAlignment = Word.WdCellVerticalAlignment.wdCellAlignVerticalCenter; // 垂直居中
--colCount;
}
else

{
previousText = currentText; // 將對比文字替換為當前的內容
previousColumnIndex = i++; // 檢索到不同的內容,將當前行下標置為先前行下標,用于合并
}
}
}方法注釋已經很詳細就不再贅述。
最后遇到的問題是無格式的段落檢索,因為在生成報告的時候需要在某些段落后填寫測試的結論,這下又把我難住了,最終終于發現了bookmark這個東東,起始我對word并不熟悉,都不知道它有書簽的功能。順便就愛你個檢索書簽的方法貼出來:

/**//// <summary>
/// 在整個文檔中根據書簽名檢索書簽對象
/// </summary>
/// <param name="name"></param>
private static Word.Bookmark getBookmarkByName(string name)


{
foreach (Word.Bookmark bm in WordDoc.Bookmarks)

{
if (bm.Name.Equals(name))
return bm;
}
return null;
}
}
例:
Word.Bookmark bm = getBookmarkByName(bookmarkName);
bm.Range.Text = "你好"; // 將檢索到書簽的內容替換為“你好”這就是這次用C#做word報表的全部問題,貌似都是小問題。
最后需要看具體的word操作demo代碼請訪問MSDN,貼個網址:
http://msdn.microsoft.com/zh-cn/library/78whx7s6(VS.80).aspx