MySQLデータベースの特定のセルにいくつかの数値を挿入できるように、Excel用アドインを開発しました。今、これらのセルを通貨にフォーマットしようとしましたが、2つの問題があります。 1.書式設定されたセルで数式を使用する場合、たとえば、合計は「353,2574€」のように表示されます。適切な方法で表示するにはどうすればよいですか? 2.一部のセルは空ですが、通貨でフォーマットする必要があります。合計式に使用したのと同じ形式を使用して何かを入力すると、表示されるのは数字だけです。 「€」なし、何もない。それは何ですか? Excel.Rangeを指定し、これを使用して範囲をフォーマットしました
sum.NumberFormat = "#.## €";
しかし、私も試しました
sum.NumberFormat = "0,00 €";
sum.NumberFormat = "#.##0,00 €";
誰か考えますか?
これは私のために動作します。通貨を小数点以下2桁にフォーマットし、カンマを桁区切り記号として使用するExcelテストアプリがあります。以下は、Excelファイルにデータを書き込むコンソールアプリケーションです。
Microsoft.Office.Interop.Excel dllを参照していることを確認してください
using System.Collections.Generic;
using Excel = Microsoft.Office.Interop.Excel;
namespace ConsoleApplication2
{
class Program
{
static void Main(string[] args)
{
var bankAccounts = new List<Account> {
new Account { ID = 345678, Balance = 541.27},
new Account {ID = 1230221,Balance = -1237.44},
new Account {ID = 346777,Balance = 3532574},
new Account {ID = 235788,Balance = 1500.033333}
};
DisplayInExcel(bankAccounts);
}
static void DisplayInExcel(IEnumerable<Account> accounts)
{
var excelApp = new Excel.Application { Visible = true };
excelApp.Workbooks.Add();
Excel._Worksheet workSheet = (Excel.Worksheet)excelApp.ActiveSheet;
workSheet.Cells[1, "A"] = "ID Number";
workSheet.Cells[1, "B"] = "Current Balance";
var row = 1;
foreach (var acct in accounts)
{
row++;
workSheet.Cells[row, "A"] = acct.ID;
workSheet.Cells[row, "B"] = acct.Balance;
}
workSheet.Range["B2", "B" + row].NumberFormat = "#,###.00 €";
workSheet.Columns[1].AutoFit();
workSheet.Columns[2].AutoFit();
}
}
public class Account
{
public int ID { get; set; }
public double Balance { get; set; }
}
}
出力