1. 程式人生 > >使用C# 將Excel1 中sheet1 的數據復制粘貼到Excel2中的sheet2

使用C# 將Excel1 中sheet1 的數據復制粘貼到Excel2中的sheet2

c# 數據轉換 star 插件 ssi sta read source exc

最近在項目中有這個需求, 在網上找的資料哦也有限 。

最開始想的是用openxmlsdk 只能在同一個Excel表中數據復制!

1、使用openxml sdk 復制Excel 中Sheet1 的數據到sheet2;

 1  /// <summary>
 2         ///使用openxmlsdk 轉換數據 原理是通過CloneNode克隆  目前只完成同表之間的全部復制! 
 3         /// </summary>
 4         /// <param name="path">Excel路徑</param>
 5         /// <param name="sheet1"></param>
6 /// <param name="sheet2"></param> 7 public static void Dome2(string path1, string sheet1, string sheet2) 8 { 9 SpreadsheetDocument document1 = SpreadsheetDocument.Open(path1, false); 10 11 Sheet sheet2 = document1 .WorkbookPart.Workbook.Descendants<Sheet>().Where(p => p.Name == sheet2).First();
12 WorksheetPart worksheet2 = (WorksheetPart)document1 .WorkbookPart.GetPartById(sheet2.Id); 13 14 ////查找目標模版Sheet 頁 15 WorksheetPart sourceWorksheetPart = SpreadsheetReader.GetWorksheetPartByName(document1, sheet1); 16 17 //通過深拷貝的方式直接拷貝目標模版的數據格式部分的 XML。 18
worksheet2.Worksheet = (Worksheet)sourceWorksheetPart.Worksheet.CloneNode(true); 19 20 worksheet2.Worksheet.Save(); 21 sourceWorksheetPart.Worksheet.Save(); 22 23 }

2、使用vs 自帶的Excel插件完成 兩表之間的數據轉換

 1  /// <summary>
 2         /// 
 3         /// </summary>
 4         /// <param name="filepath"></param>
 5         /// <param name="filepath2"></param>
 6         public static void Dome(string filepath, string filepath2)
 7         {
 8             //
 9             Excel1.Application excel = new Excel1.Application();
10             excel.Visible = false;
11             excel.DisplayAlerts = false;
12             //打開Excel1
13             Excel1.Workbook workbook = excel.Workbooks._Open(filepath, Missing.Value, Missing.Value, Missing.Value, Missing.Value
14                 , Missing.Value, Missing.Value, Missing.Value, Missing.Value
15                 , Missing.Value, Missing.Value, Missing.Value, Missing.Value);
16             //打開Excel2
17             Excel1.Workbook workbook2 = excel.Workbooks._Open(filepath2, Missing.Value, Missing.Value, Missing.Value, Missing.Value
18               , Missing.Value, Missing.Value, Missing.Value, Missing.Value
19               , Missing.Value, Missing.Value, Missing.Value, Missing.Value);
20 
21             //
22             Excel1.Worksheet worksheet1 = (Excel1.Worksheet)workbook.Worksheets[1];
23             Excel1.Worksheet worksheet2 = (Excel1.Worksheet)workbook2.Worksheets[1];
24          //
25             Excel.Range range = worksheet1 .Cells;
26             range1.Copy(Missing.Value);
27             worksheet2 .Paste(Missing.Value, Missing.Value);
28 
29             workbook1.Save();
30             workbook2.Save();
31         }            

3、 完成Excel1中Sheet1 指定位置數據 復制到Excel2中Sheet2 指定位置;

 1 public static void Dome(string filepath, string filepath2, string rangeReference)
 2         {
 3             //
 4             Range range = new Range(rangeReference);
 5             Excel1.Application excel = new Excel1.Application();
 6             excel.Visible = false;
 7             excel.DisplayAlerts = false;
 8             //
 9             Excel1.Workbook workbook1 = excel.Workbooks._Open(filepath, Missing.Value, Missing.Value, Missing.Value, Missing.Value
10                 , Missing.Value, Missing.Value, Missing.Value, Missing.Value
11                 , Missing.Value, Missing.Value, Missing.Value, Missing.Value);
12 
13             Excel1.Workbook workbook2 = excel.Workbooks._Open(filepath2, Missing.Value, Missing.Value, Missing.Value, Missing.Value
14               , Missing.Value, Missing.Value, Missing.Value, Missing.Value
15               , Missing.Value, Missing.Value, Missing.Value, Missing.Value);
16 
17             //
18             Excel1.Worksheet worksheet1 = (Excel1.Worksheet)workbook.Worksheets[1];
19             Excel1.Worksheet worksheet2 = (Excel1.Worksheet)workbook2.Worksheets[1];
20             
21             //sheet1位置
22             Excel1.Range range1 = worksheet.Range[worksheet.Cells[range.StartRow, range.StartCol], worksheet.Cells[range.EndRow, range.EndCol]];
23             //sheet2位置
24             Excel1.Range range2 = worksheet1.Range[worksheet1.Cells[range.StartRow, range.StartCol], worksheet1.Cells[range.EndRow, range.EndCol]];
25            
26             range1.Copy(Missing.Value);
27             worksheet2.Paste(range2, false);
28 
29             workbook2.Save();
30             workbook1.Save();
31         }            

使用C# 將Excel1 中sheet1 的數據復制粘貼到Excel2中的sheet2