string.Split () не работает для чтения файла CSV - PullRequest
0 голосов
/ 05 июня 2019

Я читаю файл Excel, используя мой контроллер. Я храню все строки файла CSV в массиве. Когда я распечатываю его, я вижу содержимое массива. Но когда я перебираю каждую строку и делю запятую, я ничего не получаю и в результате не могу сохранить прочитанные значения.

Вот пример моего вывода вместе с кодом:

enter image description here

Плоский файл VAWC Neptune - это мой файл. 206 - количество строк в файле. Затем я печатаю линию вместе с ее длиной. И когда эта строка разделяется запятыми, я вижу только первый вывод, иначе все пусто.

Однако, поскольку мы продолжаем читать другие строки, этот разделенный массив не появляется.

Вот фрагмент кода, который я использую:

//files is only having a single file named VAWC Neptune flat file - new meters for inventory.csv
public ActionResult ReadFile(IEnumerable<HttpPostedFileBase> files)
{
        var fileName = Path.GetFileName(files.First().FileName);
        var destinationPath = Path.Combine(Server.MapPath("~/App_Data"), fileName);
        files.First().SaveAs(destinationPath);
try
{
     string[] read = System.IO.File.ReadAllLines(destinationPath);
     System.Diagnostics.Debug.WriteLine(read.Length);
     for (int i = 0; i < read.Length; i++)
     {
        System.Diagnostics.Debug.WriteLine(read[i]);
        List<string> s = read[i].Replace(Environment.NewLine,"").Split(new char[] { ',' }, StringSplitOptions.None).ToList<string>();
        System.Diagnostics.Debug.WriteLine("Length of words in line:" + s.Capacity);
        for (int j = 0; j < s.Capacity; j++)
        {
            System.Diagnostics.Debug.WriteLine("Data:s[" + j + "]" + s[j]);
        }
     }
}

Я перепробовал так много возможных способов, но ничего не помогло.

1 Ответ

0 голосов
/ 11 июня 2019

Из Excel в CSV, верно. Вот как бы я это сделал.

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using Excel = Microsoft.Office.Interop.Excel;

namespace WindowsFormsApplication1
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {

            Excel.Application xlApp = new Excel.Application();
            Excel.Workbook xlWorkBook = xlApp.Workbooks.Open(@"C:\Users\Ryan\Desktop\Coding\DOT.NET\Samples C#\Excel Workbook - Save Each Sheet as a CSV File\Book1.xlsx");
            xlApp.Visible = true;
            foreach (Excel.Worksheet sht in xlWorkBook.Worksheets)
            {
                sht.Select();
                xlWorkBook.SaveAs(string.Format("{0}{1}.csv", @"C:\Users\Ryan\Desktop\Coding\DOT.NET\Samples C#\Excel Workbook - Save Each Sheet as a CSV File to CSV\", sht.Name), Excel.XlFileFormat.xlCSV, Excel.XlSaveAsAccessMode.xlNoChange);

            }
            xlWorkBook.Close(false);

        }

    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...