🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
ClosedXML

ClosedXMLは、Excel形式ファイル(.xlsx, .xlsm)の操作や読み書きのための.NETライブラリです。

C#

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

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

Q&A

解決済

2回答

6238閲覧

ClosedXMLで『10/28』を文字列として出力したい

morinokuma0621

総合スコア81

ClosedXML

ClosedXMLは、Excel形式ファイル(.xlsx, .xlsm)の操作や読み書きのための.NETライブラリです。

C#

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

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

0グッド

0クリップ

投稿2019/10/28 07:52

編集2019/10/28 08:04

ClosedXMLを使ってExcelに出力しようとしているのですが、年を含まない10月28日という意味で**『10/28』を出力したいのですが、どうやっても『2019/10/28』『43755』**という文字に置き換わって出力されてしまいます。

手順としてはテンプレートとなるExcelファイルをまず用意していて、そこに10/28を出力しています。テンプレート上のセルを事前にユーザー定義として『mm/dd』で設定していると『2019/10/28』が出力され、文字列にしておくと43755が出力されます。

セルに値を入力後に

C#

1worksheet.Cell("D3").Style.NumberFormat.Format = "mm/dd";

と設定を加えても、出力時には『2019/10/28』に勝手に置き換わっています。これをどんな形式でもいいので**『10/28』**と出力する方法はないでしょうか。


ちなみに、以前読み込むときの問題で似たような質問をしていましたが、こちらでは結局解決できませんでした。よろしくお願いいたします。
ClosedXMLで文字列のセルを読み込むと勝手に日付に変換されてしまう

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

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

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

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

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

guest

回答2

0

ベストアンサー

C#

1worksheet.Cell("D3").SetValue<string>("10/28");

これでできませんか?

投稿2019/10/28 08:45

YAmaGNZ

総合スコア10469

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

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

morinokuma0621

2019/10/28 09:07

できました!これが大正解でした! 本当に助かりました、ありがとうございます!
guest

0

本番で試したりアレンジしたりする前に、まずこれで意図通りになるかどうかを確かめてから適用してください。

  1. デスクトップに新しい Book1.xlsx を作成。
  2. A1 に 10/28 と書き、A1 の書式をユーザー定義の m/d にして保存
  3. コンソールアプリを作り、次のコードで A1 の値を出力

C#

1using System; 2using System.IO; 3using ClosedXML.Excel; 4 5namespace ConsoleApp1 6{ 7 class Program 8 { 9 static void Main() 10 { 11 string fileName = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.Desktop), "Book1.xlsx"); 12 using (var workbook = new XLWorkbook(fileName)) 13 { 14 var cell = workbook.Worksheet("Sheet1").Cell(1, 1); 15 var value = cell.GetFormattedString(); 16 Console.WriteLine(value); 17 } 18 Console.ReadKey(); 19 } 20 } 21} 22

10/28 と出力されれば成功です。

投稿2019/10/28 08:40

Zuishin

総合スコア28669

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

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

Zuishin

2019/10/28 09:00

回答の意図を補足しておきます。 質問の意図とは少し違いますが、日付を日付として読み取る方法です。これが本来の目的で、文字列として書き込むのは妥協策なのかもしれないと思いましたからこのように回答しました。
morinokuma0621

2019/10/28 09:04

ご回答ありがとうございます。ご回答いただいた内容とは違いますが、テンプレートを使わずにExcelファイルをプログラム上で新規作成してやってみたところ、『Style.NumberFormat.Format = "mm/dd"』と設定を加える手法で『10/28』と出力することができました。 できればテンプレートを使いたいとは思いますが、最悪新規作成でできることがわかったので、なんとかなりそうです。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問