###[openxml]結合したセルを含む行を削除し、下にある行を上にシフトさせるとセルが結合してしまう。
以下のようなことを実現したいと思っております。
#コード
削除とシフトについては以下のように実装しております。
C#
1WorkbookPart workBookPart = spreadSheet.WorkbookPart; 2Sheet targetSheet = (Sheet)spreadSheet.WorkbookPart.Workbook.Sheets.Elements<Sheet>().Where(s => s.Name == targetSheetName).FirstOrDefault(); 3WorksheetPart workSheetPart = (WorksheetPart)(workBookPart.GetPartById(targetSheet.Id)); 4 5SheetData sheetData = workSheetPart.Worksheet.GetFirstChild<SheetData>(); 6// 削除範囲(行番号)の指定 7var deleteRowFrom = 4; 8var deleteRowTo = 4; 9var deleteRows = sheetData.Elements<Row>().Where(r => r.RowIndex >= deleteRowFrom && r.RowIndex <= deleteRowTo).ToArray(); 10foreach (var row in deleteRows) 11{ 12 row.Remove(); 13} 14 15// 削除した領域より下の部分を上方向にシフトする 16// シフト範囲(行番号)の指定 17var shiftRowFrom = 5; 18var shiftRowTo = 6; 19 20for (int shiftRowIndex = shiftRowFrom; shiftRowIndex <= shiftRowTo; shiftRowIndex++) 21{ 22 Row shiftRow = workSheetPart.Worksheet.Descendants<Row>().Where(r => r.RowIndex == shiftRowIndex).First(); 23 shiftRow.RowIndex.Value -= (uint)(shiftRowFrom - deleteRowFrom); 24 foreach (Cell shiftCell in shiftRow) 25 { 26 var column = new Regex(@"[^a-zA-Z]").Replace(shiftCell.CellReference.Value, ""); 27 var rowIndex = uint.Parse(new Regex(@"[^0-9]").Replace(shiftCell.CellReference.Value, "")); 28 rowIndex -= (uint)(shiftRowFrom - deleteRowFrom); 29 shiftCell.CellReference.Value = column + rowIndex; 30 } 31} 32workSheetPart.Worksheet.Save(); 33
どのようにしたら実現できるかご教示お願いします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。