Невозможно найти CSV-файл в ASP.NET - PullRequest
1 голос
/ 25 ноября 2011

Любой, кто знает, как решить эту ошибку, пожалуйста, помогите мне. Ниже мой код для чтения файла CSV. Когда я попытался загрузить, он показал мне * Ошибка сервера в «/» приложении. Не удалось найти файл 'C: / ... csv * Я новичок в c #.

ReadCSV

    string filename = FileUpload1.PostedFile.FileName;

    using (CsvFileReader reader = new CsvFileReader(filename))
    {
        CsvRow row = new CsvRow();
        while (reader.ReadRow(row))
        {
            foreach (string s in row)
            {
                Console.Write(s);
                Console.Write(" ");
                TextBox1.Text += s;
            }
            Console.WriteLine();
        }
    }

CSVClass

  public class CsvFileReader : StreamReader
    {
        public CsvFileReader(Stream stream)
            : base(stream)
        {
        }

        public CsvFileReader(string filename): base(filename)
        {
        }

        /// <summary>
        /// Reads a row of data from a CSV file
        /// </summary>
        /// <param name="row"></param>
        /// <returns></returns>
        public bool ReadRow(CsvRow row)
        {
            row.LineText = ReadLine();
            if (String.IsNullOrEmpty(row.LineText))
                return false;

            int pos = 0;
            int rows = 0;

            while (pos < row.LineText.Length)
            {
                string value;

                // Special handling for quoted field
                if (row.LineText[pos] == '"')
                {
                    // Skip initial quote
                    pos++;

                    // Parse quoted value
                    int start = pos;
                    while (pos < row.LineText.Length)
                    {
                        // Test for quote character
                        if (row.LineText[pos] == '"')
                        {
                            // Found one
                            pos++;

                            // If two quotes together, keep one
                            // Otherwise, indicates end of value
                            if (pos >= row.LineText.Length || row.LineText[pos] != '"')
                            {
                                pos--;
                                break;
                            }
                        }
                        pos++;
                    }
                    value = row.LineText.Substring(start, pos - start);
                    value = value.Replace("\"\"", "\"");
                }
                else
                {
                    // Parse unquoted value
                    int start = pos;
                    while (pos < row.LineText.Length && row.LineText[pos] != ',')
                        pos++;
                    value = row.LineText.Substring(start, pos - start);
                }

                // Add field to list
                if (rows < row.Count)
                    row[rows] = value;
                else
                    row.Add(value);
                rows++;

                // Eat up to and including next comma
                while (pos < row.LineText.Length && row.LineText[pos] != ',')
                    pos++;
                if (pos < row.LineText.Length)
                    pos++;
            }
            // Delete any unused items
            while (row.Count > rows)
                row.RemoveAt(rows);

            // Return true if any columns read
            return (row.Count > 0);
        }
    }

Ответы [ 2 ]

1 голос
/ 25 ноября 2011

FileUpload1.PostedFile.FileName - это имя файла из вашего клиента / браузера - оно не содержит пути ...

Вы либо используете FileUpload1.PostedFile.InputStream для доступа к нему

using (CsvFileReader reader = new CsvFileReader(FileUpload1.PostedFile.InputStream))

ИЛИ сначала вы сохраняете его на диск (где бы вам ни потребовались разрешения) через FileUpload1.PostedFile.SaveAs, а затем получаете доступ к этому файлу.

0 голосов
/ 25 ноября 2011

Вам необходимо сначала сохранить файл, который загружается на диск. Примерно так:

string fileSavePath= Sever.MapPath("/files/" + FileUpload1.PostedFile.FileName);
FileUpload1.SaveAs(fileSavePath);

using (CsvFileReader reader = new CsvFileReader(fileSavePath))
....

Не проверял этот код, но должен дать вам отправную точку.

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