Удалить столбцы из CSV, а затем сохранить в другой путь к папке - PullRequest
0 голосов
/ 29 ноября 2018

Мне нужен скрипт, который открывает CSV из определенного пути к файлу, удаляет определенные столбцы и затем экспортирует CSV в указанную папку.

Из-за других сценариев, которые будут интегрированы с этим на более позднем этапе, я решил сделать это с помощью C #.

Ранее я использовал Perl и достиг желаемого результата, но он не подходит для моего приложения.

Я нашел эту ссылку , где я нашел этот код;

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.IO;

namespace CSV
{
class CSV
{
    private Dictionary<Tuple<int, int>, string> _data;
    private int _rows;
    private int _cols;

    public int Rows { get { return _rows; } }
    public int Cols { get { return _cols; } }

    public CSV()
    {
        Clear();
    }

    public void Clear()
    {
        _rows = 0;
        _cols = 0;
        _data = new Dictionary<Tuple<int, int>, string>();
    }

    public void Open(StreamReader stream, char delim = ',')
    {
        string line;
        int col = 0;
        int row = 0;

        Clear();

        while ((line = stream.ReadLine()) != null)
        {
            if (line.Length > 0)
            {
                string[] values = line.Split(delim);
                col = 0;
                foreach (var value in values)
                {
                    this[col, row] = value;
                    col++;
                }
                row++;
            }
        }
        stream.Close();
    }

    public void Save(StreamWriter stream, char delim = ',')
    {
        for (int row = 0; row < _rows; row++)
        {
            for (int col = 0; col < _cols; col++)
            {
                stream.Write(this[col, row]);
                if (col < _cols - 1)
                {
                    stream.Write(delim);
                }
            }
            stream.WriteLine();
        }
        stream.Flush();
        stream.Close();
    }

    public string this[int col, int row]
    {
        get
        {
            try
            {
                return _data[new Tuple<int, int>(col, row)];
            }
            catch
            {
                return "";
            }
        }

        set
        {
            _data[new Tuple<int, int>(col, row)] = value.ToString().Trim();
            _rows = Math.Max(_rows, row + 1);
            _cols = Math.Max(_cols, col + 1);
        }
    }

    static void Main(string[] args)
    {
        CSV csv = new CSV();

        csv.Open(new StreamReader(@"C:\mid\Dev\CSV_Splitter\VR_Path\New\Import_User_Sample_en.csv"));


        csv[0, 0] = "Column0";
        csv[1, 1] = "100";
        csv[2, 2] = "200";
        csv[3, 3] = "300";
        csv[4, 4] = "400";




csv.Save(new StreamWriter(@"C:\mid\Dev\CSV_Splitter\VR_Path\Proccessed\test_out.csv"));
    }
}
}

Это использует C #, чтобы открыть файл CSV, манипулировать им и сохранить его по новому пути.

Я хочу удалить столбцы 0, 1, 2 и 3 из файла csv вместо манипулирования данными.

Кто-нибудь может помочь?

1 Ответ

0 голосов
/ 29 ноября 2018

Вы можете использовать опубликованный код, просто измените метод Save, инициализируйте переменную col с 4, и все готово.

public void Save(StreamWriter stream, char delim = ',')
{
    if(_cols > 4) 
    {
    for (int row = 0; row < _rows; row++)
    {
        for (int col = 4; col < _cols; col++)
        {
            stream.Write(this[col, row]);
            if (col < _cols - 1)
            {
                stream.Write(delim);
            }
        }
        stream.WriteLine();
    }
    }
    stream.Flush();
    stream.Close();
}

Обновление:

Чтобы исключить 10-й столбец, пропустите запись данных в 10-й позиции.

public void Save(StreamWriter stream, char delim = ',')
{
    if(_cols > 4) 
    {
    for (int row = 0; row < _rows; row++)
    {
        for (int col = 4; col < _cols; col++)
        {
            if(col != 10)
            {
                stream.Write(this[col, row]);
                if (col < _cols - 1)
                {
                    stream.Write(delim);
                }
            }
        }
        stream.WriteLine();
    }
    }
    stream.Flush();
    stream.Close();
}
...