【问题标题】:Extra Line and Comma in String Issues字符串问题中的额外行和逗号
【发布时间】:2013-05-30 23:50:57
【问题描述】:

我有以下代码输入 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(";")]
public sealed class StoreItems
{

[FieldOptional()]
public String Attribut;

[FieldOptional()]
public String ProductName;

[FieldOptional()]
public String Size;

[FieldOptional()]
public String Brand;

[FieldOptional()]
public String Type;

[FieldOptional()]
public String ParentSKU;

[FieldOptional()]
public String SKU;

[FieldOptional()]
public String Stock;

[FieldOptional()]
public String RetailEURO;

[FieldOptional()]
public String SuggestedsellEURO;

[FieldOptional()]
public String Weight;

[FieldOptional()]
public String Description;

[FieldOptional()]
public String Photo1;

[FieldOptional()]
public String Photo2;

[FieldOptional()]
public String Photo3;

[FieldOptional()]
public String Gender;

[FieldOptional()]
public String EAN13;
}

public class RunProgram
{
    public static void Main()
    {
        FileHelperEngine engine = new FileHelperEngine(typeof(StoreItems));
        StoreItems[] res = engine.ReadFile("Presta.csv") as StoreItems[];

        Directory.CreateDirectory("Output");
        StreamWriter sw = new StreamWriter(@".\Output\" + DateTime.Now.ToString("hhmmss") + ".csv");
        sw.AutoFlush = true;
        Console.SetOut(sw);

        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, " +
            "thumbnail_external_url, small_image_external_url, image_external_url");

        foreach(StoreItems item in res)
        {
            string newtype = null;
            int visibility = 0;

            if (item.Attribut == "Parent")
            {
                newtype = "Configurable";
                visibility = 4;
            }
            else if (item.Attribut == "Child")
            {
                newtype = "Simple";
                visibility = 1;
            }

            int isinstock;

            int stockint;

            try
            {
               stockint = Convert.ToInt32(item.Stock);
            }
            catch
            {
               stockint = 0;
            }

            if (stockint > 0)
            {
                isinstock = 1;
            }
            else
            {
                isinstock = 0;
            }


            Console.WriteLine(newtype + ", base, 0, " + visibility + ", " + isinstock + ", " + item.ProductName + ", " + item.Size + ", " +
                item.Brand + ", " + item.Gender + ", " + item.Type + ", " + item.SKU + ", " + item.Stock + ", Sí, " + @""""+item.Photo1+ ", "+item.Photo2+", "+item.Photo3+@"""" + ", " + item.Photo1 + ", " + item.Photo1 +
                ", " + item.Photo1);

        }



    }


}

编辑:我刚刚意识到第二行是从输入文件的读取中添加的。我只需要找到一种方法来忽略第一行。这些领域似乎也不再抵消。现在只是如何在 csv 中使用逗号?

【问题讨论】:

标签: c# csv filehelpers


【解决方案1】:

第二个问题;

您不必使用逗号作为分隔符,您可以使用任何您想要的字符。因此,作为一个快速修复,为什么不将输出中的“,”分隔符更改为“|”。

当然,如果您还需要输出 '|'在你的文本中,这不会有帮助,但如果没有 - 快速修复让你继续。

【讨论】:

    【解决方案2】:

    一个问题;你有;

    string newtype = null;
    int visibility = 0;
    
    if (item.Attribut == "Parent")
    {
        newtype = "Configurable";
        visibility = 4;
    }
    else if (item.Attribut == "Child")
    {
        newtype = "Simple";
        visibility = 1;
    }
    

    如果item.Attribut 既不是“父”也不是“子”,则不设置newtype。因此,为什么您的示例输出中的第一个字段是空白的。

    【讨论】:

    • 是的,我知道这一点。我正在使用的文件将始终包含其中之一,除非该字段应为空。所以我使用newtype 作为我的第一个字段,如果原始字段不是这两个字段,它会返回空白。至于您的其他答案,那是个好主意!我只需要检查以确保该文件将进入的程序将接受该格式。
    猜你喜欢
    • 2017-09-13
    • 2020-09-12
    • 1970-01-01
    • 2019-08-31
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多