使用C# 將Excel1 中sheet1 的數據復制粘貼到Excel2中的sheet2
阿新 • • 發佈:2017-07-17
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。 18worksheet2.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