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

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

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

XMLは仕様の1つで、マークアップ言語群を構築するために使われています。

C#

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

Q&A

解決済

1回答

11971閲覧

C#でClosedXmlを使用した、日本語のシート名と「&」を含む参照式の値を取得する方法

退会済みユーザー

退会済みユーザー

総合スコア0

XML

XMLは仕様の1つで、マークアップ言語群を構築するために使われています。

C#

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

0グッド

0クリップ

投稿2016/11/02 07:00

C#でExcelファイルを読み込むツールを作成しているものです。
Excelの読み込みにClosedXMLを使用しています。
以下のような例を解決する方法があるか模索しております。

あるExcelファイル「Book1.xlsx」があります。
シートは2シートあり、「hoge」「huga」とシート名が付けられています。
それぞれのシートのA1セルに以下が入力されているとします。

・hugaシートのA1セルに数値「500」
・hogeシートのA1セルに数式「=100&huga!$A$1」

この条件で以下のコードから結果をコンソールで出力すると、期待通り
「100500」を得ることができます。

using System; using System.Collections.Generic; using System.Linq; using System.Text; using ClosedXML.Excel; namespace ConsoleApplication2 { class Program { static void Main(string[] args) { using (var iwb = new XLWorkbook(@"C:\Users\hoge\Desktop\Book1.xlsx")) { var iws = iwb.Worksheet("hoge"); var hogeCellA = iws.Cell(1, 1).Value; Console.WriteLine(hogeCellA); Console.ReadLine(); } } } }

しかし、シート「huga」を「ふが」に変更し、hogeのA1セルが「=100&ふが!$A$1」の状態でコードを走らせると「Exceptionはハンドルされませんでした。Identifier expected.」とエラーが表示されます。
「=ふが!$A$1」であれば問題なく「500」が出力されますが、「&」で組み合わせたい場合にエラーになります。

何度か検証した結果シート名が日本語や''で囲まれているものが参照式にあるとエラーになるようで、シート名がアルファベットの場合だと問題なく運用できることがわかりました。
できればシート名に制限をかけたくないので、せめてシート名が日本語の場合でも読み込めるようにする方法はないのでしょうか?

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

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

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

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

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

himakuma

2016/11/02 08:41

Microsoft.Office.Interop.Excel使用しないのはなぜですか?
退会済みユーザー

退会済みユーザー

2016/11/02 12:41

ツールを使う条件にOfficeがインストールされていないPCでの使用を想定しています。また、次のサイトを参考にClosedXMLでの開発に挑戦しています。http://qiita.com/midori44/items/acab9106e6dad9653e73
guest

回答1

0

ベストアンサー

試してはいないのですが、一時的に英字のシート名に変更して、
参照も変更後の名称に変更してから、値を取得するのはどうでしょうか?
根本的な解決にはなりませんが。。。

投稿2016/11/02 13:28

himakuma

総合スコア952

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

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

退会済みユーザー

退会済みユーザー

2016/11/08 03:42

やはり日本語シートの読み込みはできないようです。 himakumaさんの回答、VBA、またはアルファベットでシート名を記述する方法しか ないようでした。 どうもありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問