CSV ファイルを解析し、データを構造体に配置しています。この質問の を使用しTextFieldParser
ていますが、 を返すことを除いて、魅力のように機能しています。現在、私は醜いプロセスを持っています: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];
String
構造体は、である AccountID を除いて、であるすべてのフィールドで構成されint
ます。それらが強く型付けされていないのは私を悩ませますが、今のところそれを見てみましょう. parser.ReadFields()
a を返すことを考えると、配列内の値で構造体を埋める (おそらく、になる必要があるString[]
などのいくつかの値を変換する) より効率的な方法はありますか?row[0]
int
**編集:**どのような種類のソリューションが機能するかに影響を与える可能性があることを言及するのを忘れていた 1 つの制限は、この構造体が[Serializable]
Tcp であり、別の場所に送信されることです。