El ejemplo de Simon no me funcionó, y sospecho que es una diferencia de lenguaje. En C# este es el aspecto de mi cadena de formato de trabajo
var linebreak = (i++ == list.Count) ? "" : "\r\n";
csv += String.Format("=\"{0}\",{1},{2},{3},=\"{4}\"{5}",
item.Value, item.Status, item.NewStatus, item.Carrier, c.Status, linebreak);
y este es el aspecto del archivo de salida
="abababababab",INVALID,INVALID,USPS,="",
="9500100030492359000149",UNKNOWNSTATUS,DELIVERED,USPS,="3"
="9500100030492359000149",UNKNOWNSTATUS,DELIVERED,USPS,="3"
="9500100030492359000149",UNKNOWNSTATUS,DELIVERED,USPS,="3"
="9500100030492359000149",UNKNOWNSTATUS,DELIVERED,USPS,="3"
="9400110200793482982812",UNKNOWNSTATUS,DELIVERED,USPS,="3"
="9400110200793482982812",UNKNOWNSTATUS,DELIVERED,USPS,="3"
="9400110200793000216184",UNKNOWNSTATUS,INVALID,USPS,=""
Como se puede ver, el formato en el archivo de salida es ="VALUE",
no "=""VALUE""",
que creo que puede ser una convención de Visual Basic.
Estoy usando Excel 2010. Por cierto, Google Sheets no abrirá/convertirá un archivo con este formato. Funcionará si eliminas el signo de igualdad, es decir, "VALUE",
- Excel seguirá abriendo el archivo pero ignorará el hecho de que quieres que tus columnas sean cadenas.