##[openxml]行を削除して、上に詰めたい。
openxmlで以下の画像の様に1行を削除して下の行を上に詰めたいと思っています。
調べてみましたが、1行の値を消す(行自体は残る)ものしか見つけられませんでした。
C#
1static void Main(string[] args) 2{ 3 var fileName = "ファイル.xlsx"; 4 5 var byteArray = System.IO.File.ReadAllBytes(fileName); 6 var fileSheetName = "sheet1"; 7 8 using (SpreadsheetDocument spreadSheet = SpreadsheetDocument.Open(fileName, true)) 9 { 10 WorkbookPart workBookPart = spreadSheet.WorkbookPart; 11 Sheet targetSheet = (Sheet)spreadSheet.WorkbookPart.Workbook.Sheets.Elements<Sheet>().Where(s => s.Name == fileSheetName).FirstOrDefault(); 12 if (targetSheet == null) 13 { 14 return; 15 } 16 17 WorksheetPart worksheetPart = (WorksheetPart)(workBookPart.GetPartById(targetSheet.Id)); 18 19 SheetData sheetData = worksheetPart.Worksheet.GetFirstChild<SheetData>(); 20 21 var rows = sheetData.Elements<Row>().Where(r => r.RowIndex >= 14 && r.RowIndex < 121).ToArray(); 22 23 foreach(var row in rows) { 24 row.Remove(); 25 } 26 worksheetPart.Worksheet.Save(); 27}
どのようにしたら実現できますでしょうか?
ご教授お願いします。
#ishi9様のアドバイス後
C#
1static void Main(string[] args) 2{ 3 var templateName = "テスト.xlsx"; 4 5 var byteArray = System.IO.File.ReadAllBytes(templateName); 6 var templateSheetName = "Sheet1"; 7 8 using (SpreadsheetDocument spreadSheet = SpreadsheetDocument.Open(templateName, true)) 9 { 10 WorkbookPart workbookPart = spreadSheet.WorkbookPart; 11 Sheet targetSheet = (Sheet)spreadSheet.WorkbookPart.Workbook.Sheets.Elements<Sheet>().Where(s => s.Name == templateSheetName).FirstOrDefault(); 12 if (targetSheet == null) 13 { 14 return; 15 } 16 17 WorksheetPart worksheetPart = (WorksheetPart)(workbookPart.GetPartById(targetSheet.Id)); 18 19 SheetData sheetData = worksheetPart.Worksheet.GetFirstChild<SheetData>(); 20 var refRowIndex = 4; 21 var iEndRowIndex = 12; 22 Row refRow = worksheetPart.Worksheet.Descendants<Row>().Where(r => r.RowIndex == refRowIndex).First(); 23 24 refRow.Remove(); 25 26 for (int index = refRowIndex + 1; index <= iEndRowIndex; index++) 27 { 28 Row refRow1 = worksheetPart.Worksheet.Descendants<Row>().Where(r => r.RowIndex == index).First(); 29 refRow1.RowIndex.Value--; 30 } 31 32 worksheetPart.Worksheet.Save(); 33 } 34}
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/09/12 05:33
2016/09/12 05:38
2016/09/12 06:29
2016/09/12 07:58