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

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

新規登録して質問してみよう
ただいま回答率
87.20%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

受付中

Excel(xlsx)のセルに設定した外部リンクをC#で扱いたい

cancat
cancat

総合スコア0

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

2回答

0評価

0クリップ

4421閲覧

投稿2017/10/20 08:54

編集2022/01/12 10:55

こんにちは。
Windows10でWPFのアプリケーションを開発しています。
Visual Studio 2017 Proを使っています。

###前提・実現したいこと
Excel(xlsx)のセルに設定した外部リンクをC#で扱いたいです。

###試したこと
(1)xlsxのシートに、値を設定。
='C:\Excelリンクテスト[Original.xlsx]Sheet1'!$A$1

(2)そのxlsxファイルを、.zipにリネームして確認。
リンクは、セルではなく、
C:\Excelリンクテスト\Link\xl\externalLinks_rels\externalLink1.xml.rels
に値を保持。

xml

<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/externalLinkPath" Target="Original.xlsx" TargetMode="External"/></Relationships>

となっている。
とすると、
Relationship
Id="rId1"
Target="Original.xlsx"
なので、XMLでRelationshopを探せばよさそう。

(3)ClosedXML, EPPlusを使ってセルのValue, Fomulaを読んでみる。
EPPlusでは該当のcellのFomulaは、"[1]Sheet1!$A$1"。とすると[1]を先のRelationshipで、rId1で引いてTargetのOriginal.xlsxに置き換えればよいか。
セルにはフルパスで書いたのに、相対パスになっているから、そこも直す必要あり。

###発生している問題・エラーメッセージ
ところが、EPPlusにもClosedXMLにも、Relationshipsが見あたらない!

###該当のソースコード

C#

FileInfo originalfile = new FileInfo(@"C:\Excelリンクテスト\Link.xlsx"); using (var excel = new ExcelPackage(originalfile)) { foreach (var worksheet in excel.Workbook.Worksheets) { var cell = worksheet.Cells[1, 1]; if (cell.Formula.ToString().Contains("[1]")) { //< Relationships xmlns = "http://schemas.openxmlformats.org/package/2006/relationships" >< Relationship Id = "rId1" Type = "http://schemas.openxmlformats.org/officeDocument/2006/relationships/externalLinkPath" Target = "Original.xlsx" TargetMode = "External" /></ Relationships > cell.Value = 500;//<=ここで一時停止していろいろ見てみるがRelationshopがない。 } }

https://github.com/JanKallman/EPPlus
でEPPlusのソースを取得し、見たところ、
ExcelWorksheets.csの772行に、

string CreateWorkbookRel(string Name, int sheetID, Uri uriWorksheet, bool isChart) { //Create the relationship between the workbook and the new worksheet var rel = _pck.Workbook.Part.CreateRelationship(UriHelper.GetRelativeUri(_pck.Workbook.WorkbookUri, uriWorksheet), Packaging.TargetMode.Internal, ExcelPackage.schemaRelationships + "/" + (isChart ? "chartsheet" : "worksheet")); _pck.Package.Flush(); //Create the new sheet node XmlElement worksheetNode = _pck.Workbook.WorkbookXml.CreateElement("sheet", ExcelPackage.schemaMain); worksheetNode.SetAttribute("name", Name); worksheetNode.SetAttribute("sheetId", sheetID.ToString()); worksheetNode.SetAttribute("id", ExcelPackage.schemaRelationships, rel.Id); TopNode.AppendChild(worksheetNode); return rel.Id; }

というmethodを発見。これがpublicでないから使えないのでしょうか?
でもcreateでgetじゃないな。単に読むだけなら。。。

###補足情報(言語/FW/ツール等のバージョンなど)
Microsoft Visual Studio Pro 2017
Microsoft .NET Framework
Version 4.6.01586

です。
よろしくお願いします。

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

daive
daive

2017/10/25 10:40 編集

わざわざ、ブックを分解して、内部データから、リンク先を得ようとする理由が不明です。素直に、Microsoft\.Office\.Interop\.Excel 名前空間 を使用出来ない理由は何でしょうか?また、他のツールで、ブックからデータを抜く選択肢は、考えなかったのでしょうか? また、ネット検索をすれば、EXCELのブックの仕様が探せます。
cancat
cancat

2017/10/26 02:10

なにがいいたいのかわかりません。Excelはないので、Microsoft\.Office\.Interop\.Excelは対象外です。
283cks
283cks

2017/10/26 03:02

Excelのバージョンは? あと「試したこと」の「\(2\)」が 何をしているのかわからない。 気になる項目(質問)なのですが・・・
283cks
283cks

2017/10/26 03:03

すいません。回答欄に投稿して(削除依頼しました)。こちらで返答をいただければ幸いです。
cancat
cancat

2017/10/26 09:38

\(2\)は飛ばしてください。理由を聞かれても説明できないです。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。