ExcelDataReader 更改列名
ExcelDataReader changing columns name
我正在使用 ExcelDataReader
读取 Excel 文件
Dim entireExcel As DataTableCollection
Using ofd As OpenFileDialog = New OpenFileDialog() With {.Filter = "Excel Workbook|*.xlsx|Excel 97-2003 Workbook|*.xls"}
If ofd.ShowDialog() = DialogResult.OK Then
txtFileName.Text = ofd.FileName
Using stream = File.OpenRead(ofd.FileName)
System.Text.Encoding.RegisterProvider(System.Text.CodePagesEncodingProvider.Instance)
Dim reader As IExcelDataReader = ExcelReaderFactory.CreateReader(stream)
entireExcel = reader.AsDataSet(New ExcelDataSetConfiguration() With {
.ConfigureDataTable = Function(__) New ExcelDataTableConfiguration() With {
.UseHeaderRow = True}}).Tables
End Using
End If
End Using
一切正常,只有一个例外:工作表中的列名不是 Excel 中的真实列名。如果该列与左侧的列重复,则会在名称中添加 _1、_2 等。如果缺少列名,它会创建名称 Column0、Column1、Column2 等
如何获得真实姓名,或者如何防止更改它们?
此行为的原因是如果您尝试设置重复的列名 [1],DataSet 的实现会抛出 DuplicateNameException
。 ExcelDataReader 通过为您生成唯一的名称来解决这个问题。
您需要根据您的情况找到解决方法。 F.ex 将 UseHeaderRow
设置为 false 并从数据中手动读取列名。或者根本不使用 AsDataSet()
,而是依赖 reader 的 Read()
/GetValue()
/GetXXX()
方法。
[1] https://docs.microsoft.com/en-us/dotnet/api/system.data.datacolumn.columnname
我正在使用 ExcelDataReader
读取 Excel 文件Dim entireExcel As DataTableCollection
Using ofd As OpenFileDialog = New OpenFileDialog() With {.Filter = "Excel Workbook|*.xlsx|Excel 97-2003 Workbook|*.xls"}
If ofd.ShowDialog() = DialogResult.OK Then
txtFileName.Text = ofd.FileName
Using stream = File.OpenRead(ofd.FileName)
System.Text.Encoding.RegisterProvider(System.Text.CodePagesEncodingProvider.Instance)
Dim reader As IExcelDataReader = ExcelReaderFactory.CreateReader(stream)
entireExcel = reader.AsDataSet(New ExcelDataSetConfiguration() With {
.ConfigureDataTable = Function(__) New ExcelDataTableConfiguration() With {
.UseHeaderRow = True}}).Tables
End Using
End If
End Using
一切正常,只有一个例外:工作表中的列名不是 Excel 中的真实列名。如果该列与左侧的列重复,则会在名称中添加 _1、_2 等。如果缺少列名,它会创建名称 Column0、Column1、Column2 等
如何获得真实姓名,或者如何防止更改它们?
此行为的原因是如果您尝试设置重复的列名 [1],DataSet 的实现会抛出 DuplicateNameException
。 ExcelDataReader 通过为您生成唯一的名称来解决这个问题。
您需要根据您的情况找到解决方法。 F.ex 将 UseHeaderRow
设置为 false 并从数据中手动读取列名。或者根本不使用 AsDataSet()
,而是依赖 reader 的 Read()
/GetValue()
/GetXXX()
方法。
[1] https://docs.microsoft.com/en-us/dotnet/api/system.data.datacolumn.columnname