Estoy analizando un archivo CSV y colocando los datos en una estructura. Estoy usando el TextFieldParser
de this question y está funcionando como un amuleto, excepto que devuelve un String[]
. En este momento tengo la fea proceso de:¿Completar struct con String []?
String[] row = parser.ReadFields();
DispatchCall call = new DispatchCall();
if (!int.TryParse(row[0], out call.AccountID)) {
Console.WriteLine("Invalid Row: " + parser.LineNumber);
continue;
}
call.WorkOrder = row[1];
call.Description = row[2];
call.Date = row[3];
call.RequestedDate = row[4];
call.EstStartDate = row[5];
call.CustomerID = row[6];
call.CustomerName = row[7];
call.Caller = row[8];
call.EquipmentID = row[9];
call.Item = row[10];
call.TerritoryDesc = row[11];
call.Technician = row[12];
call.BillCode = row[13];
call.CallType = row[14];
call.Priority = row[15];
call.Status = row[16];
call.Comment = row[17];
call.Street = row[18];
call.City = row[19];
call.State = row[20];
call.Zip = row[21];
call.EquipRemarks = row[22];
call.Contact = row[23];
call.ContactPhone = row[24];
call.Lat = row[25];
call.Lon = row[26];
call.FlagColor = row[27];
call.TextColor = row[28];
call.MarkerName = row[29];
La estructura consiste en todos aquellos campos siendo String
s excepción de AccountID ser un int
. Me molesta que no estén fuertemente tipados, pero vamos a ver eso por ahora. Dado que parser.ReadFields()
devuelve String[]
, ¿hay alguna forma más eficiente de completar una estructura (posiblemente convirtiendo algunos valores como row[0]
que necesitan convertirse en int
) con los valores en la matriz?
** EDIT: ** Una restricción se me olvidó mencionar que puede impacto qué tipo de soluciones va a funcionar es que esta estructura es [Serializable]
y se enviará Tcp en otro lugar.
Use la reflexión. – Grozz
La reflexión sería definitivamente menos eficiente, simplemente viviría con ella, como es – RobJohnson
CsvHelper podría serle de mucha ayuda https://github.com/JoshClose/CsvHelper/wiki/Basics – KeesDijk