1

我有一个机器生成的 excel 文件,其中有几列同名。例如:

  A       B          C       D
Group 1           Group 2
Period | Name     Period | Name 

我得到了这样的 DTO:

[ExcelColumn("Period")]
public string FirstPeriod { get; set; }
[ExcelColumn("Name")]
public string FirstName { get; set; }

[ExcelColumn("Period")]
public string SecondPeriod { get; set; }
[ExcelColumn("Name")]
public string SecondName { get; set; }

我使用以下命令来读取这些行:

var excel = new ExcelQueryFactory(filePath);
excel.WorksheetRange<T>(beginCell, endColl + linesCount.ToString(), sheetIndex);

它可以很好地读取文件,但是当我检查 DTO 的内容时,我看到所有“第二”属性都具有与“第一”属性相同的值。

这篇文章是我在搜索中找到的最接近的东西,我认为这个问题可以通过以下方式解决:

excel.AddMapping<MyDto>(x => x.FirstPeriod, "A");
excel.AddMapping<MyDto>(x => x.FirstName, "B");
excel.AddMapping<MyDto>(x => x.SecondPeriod, "C");
excel.AddMapping<MyDto>(x => x.SecondName, "D");

但我不知道如何获取 excel 列字母...

Obs:我在这背后还有一些代码,但我认为它与问题无关。

4

1 回答 1

1

您遇到的问题今天无法使用 LinqToExcel 解决,因为它包装了 OleDb 函数,然后它们根据列名映射属性,因此您丢失了用于指定列的 OleDb 选项,如“FN”(如“F1”用于“一个”)。

LinqToExcel github repo 上有一个关于此的问题。https://github.com/paulyoder/LinqToExcel/issues/85

我建议您将列的名称更改为不重复名称(例如 Period1、Name1、Period2、Name2),如果由于其机器生成而无法更改,请尝试在运行时更改标题名称。

另一种选择是在 excel 文件中进行多个查询,将范围拆分为您的组,然后稍后合并结果。

var excel = new ExcelQueryFactory(filePath);
var group1 = excel.WorksheetRange<T>(A1, B + rowCount);
var group2 = excel.WorksheetRange<T>(C1, D + rowCount);

编辑:我将开发一个功能来尝试以优雅的方式解决这个问题,所以将来你可能有一个更灵活的选项来映射列和属性(如果他们接受我的拉取请求)

于 2016-01-07T20:01:31.047 回答