Excel单元格格式化(货币)

19
我为Excel开发了一个插件,可以将MySQL数据库中的某些数字插入到特定单元格中。现在我尝试将这些单元格格式化为货币格式,并且我遇到了两个问题: 1. 在格式化单元格上使用公式时,例如总和,“353,2574€”会被显示出来。我应该怎么做才能以适当的方式显示它呢? 2. 有些单元格是空的,但也必须按货币格式进行格式化。当我使用与总和公式相同的格式并输入内容时,仅显示数字。没有"€",为什么呢? 我指定了一个Excel.Range,并将其用于格式化范围。
sum.NumberFormat = "#.## €";

但是我也尝试过

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

有人有什么想法吗?

1个回答

19
这个对我有用。我有一个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; }
    }
}

输出

enter image description here


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接