Строки перепутались при преобразовании текстовых файлов с разделителями трубы в файл Excel .CSV - PullRequest
0 голосов
/ 09 ноября 2011

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

Однако после этого я понимаю, что с некоторыми строками есть некоторые проблемы.

например. Имя [Чуа Вэй Лун] (предположительно в одном столбце), в конечном итоге «Чуа Вэй» находится в одном столбце, «Лун» в следующем столбце.

Я просмотрел текстовый файл и не нашел каналов между именем, и не смог найти решение.

Ниже приведен мой код для функции:

protected void SaveAsExcelBtn_Click(object sender, EventArgs e)
    {


        //string strExcelOutputFilename = "C:/Documents and Settings/rhlim/My Documents/" + DateTime.Now.ToString("yyyyMMddHHmmss") + xlExtension;

        // Before attempting to import the file, verify 
        // that the FileUpload control contains a file. 
        if (TextFile.HasFile)
        {
            // Get the name of the Excel spreadsheet. 
            string strFileName = Server.HtmlEncode(TextFile.FileName);

            // Get the extension of the text. 
            string strExtension = Path.GetExtension(strFileName);

            // Validate the file extension. 
            if (strExtension != ".TXT" && strExtension!=".txt")
            {

                Response.Write("<script>alert('Invalid text file!');</script>");
                return;
            }

            // Generate the file name to save the text file.
            //string strUploadFileName = "C:/Documents and Settings/rhlim/My Documents/Visual Studio 2005/WebSites/SoD/UploadFiles/" + DateTime.Now.ToString("yyyyMMddHHmmss") + strExtension;

            if (DEMUserRoleRB.Checked)
            {
                string strExcelOutputFilename = "C:/" + "userrolelist" + xlExtension;


                using (StreamWriter outputWriter = new StreamWriter(File.Create(strExcelOutputFilename)))
                {
                    StreamReader inputReader = new StreamReader(TextFile.FileContent);
                    string fileContent = inputReader.ReadToEnd();
                    fileContent = fileContent.Replace('|', ',');
                    outputWriter.Write(fileContent);
                    //TextFile.SaveAs(strExcelOutputFilename);
                    inputReader.Close();
                    UploadStatusLabel.Text = "Conversion successful. File is stored at directory C:/";
                }

                //string strExcelOutputFilename = "C:/Documents and Settings/rhlim/My Documents/" + DateTime.Now.ToString("yyyyMMddHHmmss")+xlExtension;
                // Save the Excel spreadsheet on server. 
                //TextFile.SaveAs (strExcelOutputFilename);

            }
        }
        else Response.Write("<script>alert('Please select a file');</script>");

Пример вывода файла .csv (строки с ошибками выделены):

enter image description here

Я осознал свою ошибку, это связано с наличием запятых внутри переменных, которые вызвали разделение имени.

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

Ответы [ 2 ]

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

Вы проверили, не является ли [Чуа Вэй Лун] на самом деле [Чуа Вей, Лун]?Вы сначала избавились от запятых в данных?

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

Входные файлы разделены каналом, поскольку данные содержат запятые. Таким образом, замена разделителей на запятые вызовет возникшую проблему. Решение: оставить разделители труб. Почему вы чувствуете, что должны заменить их? Я уверен, что Excel может читать файлы с разделителями.

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