C# 格式化Excel单元格(货币)

C# 格式化Excel单元格(货币),c#,excel,format,currency,C#,Excel,Format,Currency,我为Excel开发了一个外接程序,这样您就可以将MySQL数据库中的一些数字插入到特定的单元格中。现在我尝试将这些单元格格式化为货币,但我有两个问题。 1.在格式化单元格上使用公式时,例如,总和如下所示: "353,2574€". 我必须做什么才能以适当的方式显示它? 2.某些单元格为空,但也必须使用货币进行格式化。当使用我用于求和公式的相同格式并键入某些内容时,只显示数字。没有“€”,什么都没有。那是什么? 我指定了一个Excel.Range,并使用它来设置范围的格式 sum.NumberFo

我为Excel开发了一个外接程序,这样您就可以将MySQL数据库中的一些数字插入到特定的单元格中。现在我尝试将这些单元格格式化为货币,但我有两个问题。 1.在格式化单元格上使用公式时,例如,总和如下所示: "353,2574€". 我必须做什么才能以适当的方式显示它? 2.某些单元格为空,但也必须使用货币进行格式化。当使用我用于求和公式的相同格式并键入某些内容时,只显示数字。没有“€”,什么都没有。那是什么? 我指定了一个Excel.Range,并使用它来设置范围的格式

sum.NumberFormat = "#.## €";
但我也试过了

sum.NumberFormat = "0,00 €";
sum.NumberFormat = "#.##0,00 €";

有人知道吗?

这个适合我。我有一个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; }
    }
}
使用System.Collections.Generic;
使用Excel=Microsoft.Office.Interop.Excel;
命名空间控制台应用程序2
{
班级计划
{
静态void Main(字符串[]参数)
{
var bankAccounts=新列表{
新账户{ID=345678,余额=541.27},
新帐户{ID=1230221,余额=-1237.44},
新账户{ID=346777,余额=3532574},
新账户{ID=235788,余额=1500.033333}
};
DisplayInXcel(银行账户);
}
静态void displayincel(IEnumerable账户)
{
var excelApp=new Excel.Application{Visible=true};
excelApp.Workbooks.Add();
Excel.\u工作表工作表=(Excel.Worksheet)excelApp.ActiveSheet;
工作表。单元格[1,“A”]=“ID号”;
工作表。单元格[1,“B”]=“当前余额”;
var行=1;
foreach(账户中的var账户)
{
行++;
工作表.单元格[行,“A”]=账户ID;
工作表单元格[行,“B”]=账户余额;
}
工作表.范围[“B2”,“B”+行].NumberFormat=“#,###.00€”;
工作表.Columns[1].AutoFit();
工作表.Columns[2].AutoFit();
}
}
公共类帐户
{
公共int ID{get;set;}
公共双平衡{get;set;}
}
}
输出