当前位置: 首页 > 知识库问答 >
问题:

C#。通过NPOI 2.0将xlsx数据单元导入数据表

袁旻
2023-03-14

我试图改变信仰。使用NPOI 2.0库将xlsx文件转换为数据表格式。没关系,但我在转换为字符串日期单元格时遇到了问题。当我尝试使用类似row的构造时。GetCell(j)。ToString()-引发异常“无法从文本单元格获取数值”。我试图使用DateCellValue属性,但它也引发了这个异常。对于其他单元格格式,效果很好。函数,我使用它:

private DataTable xlsxToDT(string fileName)
    {
        DataTable table = new DataTable();
        XSSFWorkbook workbook = new XSSFWorkbook(new FileStream(fileName, FileMode.Open, FileAccess.Read));
        ISheet sheet = workbook.GetSheetAt(0);
        IRow headerRow = sheet.GetRow(0);
        int cellCount = headerRow.LastCellNum;
        for (int i = headerRow.FirstCellNum; i < cellCount; i++)
        {
            DataColumn column = new DataColumn(headerRow.GetCell(i).StringCellValue);
            table.Columns.Add(column);
        }
        int rowCount = sheet.LastRowNum;
        for (int i = (sheet.FirstRowNum); i < sheet.LastRowNum; i++)
        {
            IRow row = sheet.GetRow(i);
            DataRow dataRow = table.NewRow();
            for (int j = row.FirstCellNum; j < cellCount; j++)
            {
                if (row.GetCell(j) != null)
                {
                    //EXCEPTION GENERATING IN THIS CODE
                    dataRow[j] = row.GetCell(j).ToString();
                    ////////////////////////////
                }
            }
            table.Rows.Add(dataRow);
        }
        workbook = null;
        sheet = null;
        return table;
    }

更新:如果我插入如下代码

row.GetCell(j).SetCellType(CellType.STRING);

在问题单元格中,我有像“36496.392581018517”这样的值。另一个单元格转换正确

共有3个答案

伏德义
2023-03-14

我的解决方案是创建这样的函数getValue

FileStream fs = new FileStream(@"\export.xlsx", FileMode.Open);
XSSFWorkbook wb = new XSSFWorkbook(fs);
ISheet sheet = wb.GetSheetAt(0);
// GetValue here
string text = getValueFromCell(sheet.GetRow(row).GetCell(1));

public string getValueFromCell(ICell cell) {
            string output ="";
            if (cell != null)
            {
                switch (cell.CellType)
                {
                    case CellType.String:
                        output = cell.StringCellValue;
                        break;
                    case CellType.Numeric:
                        //dataRow[j] = cell.NumericCellValue;
                        output = cell.NumericCellValue.ToString();
                        break;
                    case CellType.Boolean:
                        output = cell.BooleanCellValue.ToString();
                        //dataRow[j] = cell.BooleanCellValue;
                        break;
                    default:
                        output = "";
                        break;
                }
            }
            return output;
        }
郑浩博
2023-03-14
ICell cell = row.GetCell(j);
if (cell != null)
{
    switch (cell.CellType)
    {
        case CellType.String:
            dataRow[j] = cell.StringCellValue;
            break;
        case CellType.Numeric:
            dataRow[j] = cell.NumericCellValue;
            break;
        case CellType.Boolean:
            dataRow[j] = cell.BooleanCellValue;
            break;
        default: dataRow[j] = "ERROR";
            break;
    }
}
有睿
2023-03-14

excel文件的第二列具有日期格式(1999年12月2日)。在您当前的文化(“ru ru”)中,NPOI不认可这种格式。这似乎是NPOI中的一个错误,因为当这种情况发生时,无法从该单元格中读取任何内容。我得出的唯一方法是,在读取excel文件之前更改线程的区域性(然后在读取后将其更改回):

private DataTable xlsxToDT(string fileName)
{
    var prevCulture = Thread.CurrentThread.CurrentCulture;
    Thread.CurrentThread.CurrentCulture = CultureInfo.InvariantCulture;
    try
    {
        // Put your whole method body here.
    }
    finally
    {
        Thread.CurrentThread.CurrentCulture = prevCulture;
    }
}
 类似资料:
  • 问题内容: 通讯: 但是我想通过Ajax将我的电子邮件插入数据库。我不希望页面被重定向,因为每次刷新页面时,都会将空值插入数据库。 我只希望我的电子邮件通过Ajax插入数据库,然后再发送电子邮件,即 应该消失,并且应该有“您已成功订阅”行。 任何简短的代码将非常有用..预先感谢您:) 问题答案: 尝试这个: 和在 不要使用已弃用的。 实际上,如果您的问题是将空值插入数据库,则尝试此操作,这里不需要

  • 我正在尝试将mysql数据库导入新版本的xampp(v7.1.8)。按下导入按钮后,我收到数百条此错误消息: 请注意.\vendor\phpmyadmin\sql parser\src\UtfString.php#128未初始化字符串偏移量:516 回溯 .\vendor\phpmyadmin\sql parser\src\Lexer.php\823:phpmyadmin\SqlParser\Ut

  • 问题内容: 我想通过可手动运行以更新数据的PHP脚本将表格从CSV文件导入SQLite DB。 以下是我要实现的目标的列表: 将旧表(称为“ produkte”)重命名为product-currentdate(或删除表) 然后从CSV文件导入文件(分隔并使用ISO 8859-1字符集/ CSV文件的第一行包含表标题) 将日期保存在表“产品”中 我发现了一个由于某种原因无法运行的脚本: 我希望有人知

  • 我试图在ProductFeature表中插入product对象。但我做不到。如何在下面的impex标题中插入值?

  • 我想将数据从postgres导入到配置单元,然后输入以下命令: 但我看到这条失败的消息: 问题是什么?我如何修复这个故障???

  • 我试图使用将数据从复制到。但是,尽管我在文件中设置了变量,但仍然出现了以下错误。下面是我的代码: bashrc文件中的变量: 错误: 我还需要在这里添加/修改什么??