Хранилище Azure не находит CSV-файл - PullRequest
0 голосов
/ 19 ноября 2018

Я пытаюсь прочитать CSV-файл из моей учетной записи хранения Azure. Чтобы преобразовать каждую строку в объект и построить список этих объектов. Он продолжает ошибаться, и причина в том, что он не может найти файл (Blob not found). Файл там, это файл CSV.

File in azure storage

Ошибка:

StorageException: указанный BLOB-объект не существует. BatlGroup.Site.Services.AzureStorageService.AzureFileMethods.ReadCsvFileFromBlobAsync (контейнер CloudBlobContainer, строка fileName) в AzureFileMethods.cs + await blob.DownloadToStreamAsync (memoryStream);

 public async Task<Stream> ReadCsvFileFromBlobAsync(CloudBlobContainer container, string fileName)
    {
        // Retrieve reference to a blob (fileName)
        var blob = container.GetBlockBlobReference(fileName);

        using (var memoryStream = new MemoryStream())
        {
            //downloads blob's content to a stream
             await blob.DownloadToStreamAsync(memoryStream);
            return memoryStream;

        }

    }

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

Я также не уверен, в каком формате его принимать, так как мне нужно перебирать строки.

Я вижу примеры переноса всего файла на временный диск и работы с ним там, но это кажется непродуктивным, так как тогда я мог бы просто сохранить файл в папке wwroot вместо azure.

Какой самый подходящий способ прочитать файл csv из хранилища Azure.

1 Ответ

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

Относительно того, как выполнять итерацию по строкам, после получения потока памяти вы можете использовать StreamReader, чтобы читать их построчно.

Пример кода, как показано ниже:

using Microsoft.WindowsAzure.Storage;
using Microsoft.WindowsAzure.Storage.Blob;
using System;
using System.IO;

namespace ConsoleApp17
{
    class Program
    {
        static void Main(string[] args)
        {
            string connstr = "your connection string";
            CloudStorageAccount storageAccount = CloudStorageAccount.Parse(connstr);
            CloudBlobClient blobClient = storageAccount.CreateCloudBlobClient();
            CloudBlobContainer container = blobClient.GetContainerReference("t11");
            CloudBlockBlob blockBlob = container.GetBlockBlobReference("students.csv");
            string text="";
            string temp = "";
            using (var memoryStream = new MemoryStream())
            {
                blockBlob.DownloadToStream(memoryStream);

                //remember set the position to 0
                memoryStream.Position = 0;
                using (var reader = new StreamReader(memoryStream))
                {
                    //read the csv file as per line.
                    while (!reader.EndOfStream && !string.IsNullOrEmpty(temp=reader.ReadLine()))
                    {
                        text = text + "***" + temp;
                    }

                }


            }

            Console.WriteLine(text);
            Console.WriteLine("-------");
            Console.ReadLine();
        }
    }
}

Мой CSV-файл: enter image description here

Результат теста: enter image description here

...