質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Open XML

Open XMLは、マイクロソフト社が開発したオープンなXMLベースのオフィススイート用のファイル形式です。従来のバイナリ形式のフォーマットに代わって、XMLを用いた規格を標準ファイル形式として採用しています。

Open XML SDK

Open XML SDKは、Office2007から採用されているドキュメントファイルフォーマット。オープンソースとしてGitHubで公開されています。Office Open XMLファイルを作成したり編集することが可能です。

Q&A

解決済

1回答

6144閲覧

[openxml]結合したセルを含む行を削除し、下にある行を上にシフトさせるとセルが結合してしまう。

shikasama

総合スコア163

Open XML

Open XMLは、マイクロソフト社が開発したオープンなXMLベースのオフィススイート用のファイル形式です。従来のバイナリ形式のフォーマットに代わって、XMLを用いた規格を標準ファイル形式として採用しています。

Open XML SDK

Open XML SDKは、Office2007から採用されているドキュメントファイルフォーマット。オープンソースとしてGitHubで公開されています。Office Open XMLファイルを作成したり編集することが可能です。

0グッド

0クリップ

投稿2016/09/13 09:03

編集2016/11/10 13:49

###[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

どのようにしたら実現できるかご教示お願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

シフト処理の前に対象の結合したセルの結合を解除することで実現できました。
セルの結合解除は以下の様にやりました。

C#

1MergeCells mergeCells = workSheetPart.Worksheet.Elements<MergeCells>().First(); 2MergeCell mergeCell = mergeCells.Elements<MergeCell>().Where(c => c.Reference == "D3:E3").FirstOrDefault(); 3if (mergeCell != null) 4{ 5 mergeCell.Remove(); 6}

投稿2016/09/13 10:20

shikasama

総合スコア163

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問