使用C#和Excel进行报表开发(四)-复制单元格 【转】
在用Excel作報(bào)表的時(shí)候,可能會(huì)碰到分頁(yè)的情況,這樣就要分成多個(gè)Sheet顯示,如果要在每頁(yè)都保留表頭,就需要將第一頁(yè)作為模板設(shè)計(jì)的表頭部分拷貝到其他的Sheet上,這時(shí)就要用用到Excel中的單元格拷貝。
下面的代碼說明如何一個(gè)Sheet上的選定內(nèi)容拷貝到另一個(gè)Sheet上:
?
??????? ThisApplication = new Excel.Application();
??????? ThisWorkbook = ThisApplication.Workbooks.Open("z:\\Book1.xls", Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);
??????? ThisApplication.DisplayAlerts = false;
??????? xlSheet = (Excel.Worksheet)ThisWorkbook.Worksheets.get_Item(1);
???????
Excel.Range range = xlSheet.get_Range("A1", Type.Missing);
??????? range.Value = "123";
??????? Excel.Worksheet sheet1 = (Excel.Worksheet)ThisWorkbook.Worksheets.get_Item(2);
??????? Excel.Range range1 = sheet1.get_Range("B1", Type.Missing);
??????? range.Copy(range1);
???????
ThisWorkbook.SaveAs("z:\\Book2.xls", Type.Missing, Type.Missing,
??????????????????????????????????????? Type.Missing, Type.Missing, Type.Missing, Excel.XlSaveAsAccessMode.xlNoChange,
??????????????????????????????? Type.Missing, Type.Missing, Type.Missing, Type.Missing);
?
可以看到,核心的代碼是很簡(jiǎn)單的,就是選定一個(gè)源區(qū)域,然后指定另一個(gè)目標(biāo)區(qū)域,調(diào)用源區(qū)域的Copy方法將內(nèi)容整個(gè)復(fù)制到目標(biāo)區(qū)域,但是你會(huì)發(fā)現(xiàn)是連單元格的格式等屬性一并拷貝過去的,如果要只拷貝單元格中的文本呢?那就要用到windows剪貼板了:
xlSheet = (Excel.Worksheet)ThisWorkbook.Worksheets.get_Item(1);
Excel.Range range = xlSheet.get_Range("A1", Type.Missing);
range.Value = "123";
System.Windows.Forms.Clipboard.SetDataObject(range.Value.ToString());
Excel.Worksheet sheet1 = (Excel.Worksheet)ThisWorkbook.Worksheets.get_Item(2);
Excel.Range range1 = sheet1.get_Range("B1", Type.Missing);
sheet1.Paste(range1, false);
要注意的是,這種方式只能選一個(gè)單元格,復(fù)制一個(gè),不能選定一批單元格進(jìn)行復(fù)制。
?
上面的例子只給出了主要部分的代碼,其他的像銷毀Excel進(jìn)程等操作請(qǐng)參考前面的幾篇Excel作報(bào)表的隨筆。
轉(zhuǎn)載于:https://www.cnblogs.com/fmxyw/archive/2008/09/09/1287847.html
總結(jié)
以上是生活随笔為你收集整理的使用C#和Excel进行报表开发(四)-复制单元格 【转】的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 三星note9刷Android9,三星N
- 下一篇: c# char unsigned_dll