Question posted 2014 · +5 upvotes
I am in the unusual position of having two different templates for an Excel upload, one that is ‘human friendly’ and one that is machine generated. As such, the column data headers are different and it is difficult to align them.
As such, I would like to reference the column mappings using the ordinal position rather than the ‘name’ of the column. Currently I have this:
var excel = new ExcelQueryFactory(excelFileName);
excel.AddMapping<Student>(x => x.FirstName, "First Name");
excel.AddMapping<Student>(x => x.LastName, "Last Name");
excel.AddMapping<Student>(x => x.LastFour, "Last 4 Student ID");
excel.AddMapping<Student>(x => x.LastDate, "Last Date");
and I would like to do something like this:
var excel = new ExcelQueryFactory(excelFileName);
excel.AddMapping<Student>(x => x.FirstName, "A");
excel.AddMapping<Student>(x => x.LastName, "C");
excel.AddMapping<Student>(x => x.LastFour, "G");
excel.AddMapping<Student>(x => x.LastDate, "H");
where the letters are the column references in Excel.
Is there a way to do this?
Accepted answer +7 upvotes
if you order is the same you can call
var columnnames= excel.GetColumnNames("worksheetName");
excel.AddMapping<Student>(x => x.FirstName, columnnames[0]);
excel.AddMapping<Student>(x => x.FirstName, columnnames[1]);
excel.AddMapping<Student>(x => x.LastFour, columnnames[2]);
Top excel Q&A (6)
- Shortcut to Apply a Formula to an Entire Column in Excel +335 (2011)
- How should I escape commas and speech marks in CSV files so they work in Excel? +136 (2012)
- Convert xlsx to csv in linux command line +96 (2012)
- How to create a link inside a cell using EPPlus +50 (2011)
- IF statement: how to leave cell blank if condition is false ("" does not work) +44 (2013)
- T-SQL: Export to new Excel file +44 (2012)
excel solutions on this site
.