关于 c#:Extra Line and Comma in String 问题
Extra Line and Comma in String Issues
我有以下代码输入 CSV 文件,然后将其转换并输出 CSV 文件。我正在使用 FileHelper 读取 CSV。我有几个问题。首先,正在插入带有字段信息的额外行(见下文)。第二个问题是我添加了双引号,因此我可以在包含逗号的单元格中包含一个字符串;我找不到格式有什么问题,但它不会导入到 excel 中,只显示双引号和第一项。我尝试在导入 excel 时使用双引号转义文本选项。第三个问题是有些字段是空白的,导致字段后期偏移。
第二行字段:
|
, base, 0, 0, 0, Product Name, Size, Brand, Gender, Type, SKU, Stock, Sí,"Photo1, Photo2, Photo3", Photo1, Photo1, Photo1
|
代码:
|
using System;
using FileHelpers; using System.IO; [DelimitedRecord(";")] [FieldOptional()] [FieldOptional()] [FieldOptional()] [FieldOptional()] [FieldOptional()] [FieldOptional()] [FieldOptional()] [FieldOptional()] [FieldOptional()] [FieldOptional()] [FieldOptional()] [FieldOptional()] [FieldOptional()] [FieldOptional()] [FieldOptional()] [FieldOptional()] [FieldOptional()] public class RunProgram Directory.CreateDirectory("Output"); Console.WriteLine("_type, _product_websites, tax_class_id, _visibility, is_in_stock, name, taglia, manufacturer, gender, _attribute_set, sku, qty, use_external_images, external_gallery," + foreach(StoreItems item in res) if (item.Attribut =="Parent") int isinstock; int stockint; try if (stockint > 0)
Console.WriteLine(newtype +", base, 0," + visibility +"," + isinstock +"," + item.ProductName +"," + item.Size +"," + } } } |
编辑:我刚刚意识到第二行是从输入文件的读取中添加的。我只需要找到一种方法来忽略第一行。这些领域似乎也不再相互抵消。现在只是如何在 csv 中使用逗号?
相关讨论
- 我已经编辑了你的标题。请参阅"问题应该在标题中包含"标签"吗?",其中共识是"不,他们不应该"。
第二个问题;
你不必使用逗号作为分隔符,你可以使用任何你想要的字符。因此,作为一个快速修复,为什么不将输出中的","分隔符更改为"|"。
当然,如果你还需要输出'|'在您的文本中,这不会有帮助,但如果没有 - 快速修复让您继续前进。
一个问题;你有;
|
string newtype = null;
int visibility = 0; if (item.Attribut =="Parent") |
如果
相关讨论
- 是的,我知道这一点。我正在使用的文件将始终包含其中之一,除非该字段应为空。所以我使用
newtype 作为我的第一个字段,如果原始字段不是这两个字段,它会返回空白。至于您的其他答案,那是个好主意!我只需要检查以确保该文件将进入的程序将接受该格式。