excel - XtraReports 以编程方式设置 Excel 导入单元格格式

标签 excel import formatting xtrareport

使用 Designer 时,我可以将单元格的 XlsxFormatString 属性编辑为“#,##0.00”,结果符合预期。当我尝试以编程方式执行此操作时,如下所示,没有任何更改:

private XRTableCell CreateCell(int width, string text, bool haveColor, string color, bool isBold, DevExpress.XtraPrinting.BorderSide border, bool IsNumeric)
        {
            //MyWorkaround
            if (IsNumeric)
            {
                if (text.Contains(","))
                {
                    if (text.Length > text.IndexOf(',') + 3)
                        text = text.Remove(text.IndexOf(',') + 3);
                }
            }
            //MyWorkaround end 
            XRTableCell cell = CreateCell(width, text, haveColor, color, isBold);
            cell.Borders = border;
            if (IsNumeric)
                cell.XlsxFormatString = "#,##0.00";
            return cell;
        }

有什么建议可以使其正确吗?

最佳答案

经过对 Devexpress Documents 的一些研究和数十次尝试后,我找到了这个解决方案;

  1. 如果输出不会用于某些计算:

    XtraReport myReport = new XtraReport();
    myReport.ExportOptions.Xls.TextExportMode = TextExportMode.Text;
    myReport.ExportOptions.Xlsx.TextExportMode = TextExportMode.Text;
    
  2. 如果输出单元格类型由于某种原因很重要:

    float myTextValue;
    if (float.TryParse(textToPrint,out  myValue))
            {
                string decSeperator = CultureInfo.CurrentCulture.NumberFormat.NumberDecimalSeparator;
                if (text.Contains(decSeperator))
                {
                    if (textToPrint.Length > textToPrint.IndexOf(decSeperator[0]) + 3)
                        textToPrint= textToPrint.Remove(textToPrint.IndexOf(decSeperator[0]) + 3);
                }
            }
    

如果可以在文本中找到分隔符,则会在 2 位数字后进行修剪。如果最后一位数字大于 5 等,可以像舍入一样更改。

XtraReports 导出工具已经确定文本是否为数字,并自行设置单元格类型

如果有人找到更好的解决方案,请随时交流。

关于excel - XtraReports 以编程方式设置 Excel 导入单元格格式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32717571/

相关文章:

mysql - 从数据库导入/导出数据同时绕过 Active Record 验证的最佳方法

datetime - 时间和日期解析的测试数据(多种格式)

java - 有没有更好的方法将数字转换为 Java 中具有可变十进制精度的填充字符串?

excel - CountIf 列标题与星期几匹配

excel - 在本地窗口中展开自定义类节点会导致 Excel 静默崩溃

mysql - phpMyAdmin SQL 导入傻瓜教程

java - 如何从具有多个 TTF 文件的字体系列导入自定义 java.awt.Font? (包括一个例子)

excel - 如何使用 AppleScript 保存为 excel 文件

excel - 内存不足错误 - 尝试使用 Win API 检查 ErrorHandler 中的内存使用情况

c# - 使用 toString 进行格式化,以便我得到某种图表