Как мне разобрать текстовый файл с помощью C #? - PullRequest
0 голосов
/ 26 января 2011

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

Пример формата текстового файла:

Name;Surname;Birthday;Address

Name;Surname;Birthday;Address

Winforms

Name: textboxname

Surname: textboxsurname

Birthday: textboxbirth

Address: textboxaddress

Я также хочу, чтобы это приложение Winforms содержало кнопки Next и Back, чтобы оно могло циклически перебирать записи.

Я не знаю, как это сделать в C #. С чего начать?

Ответы [ 4 ]

5 голосов
/ 26 января 2011
foreach (string line in File.ReadAllLines("path-to-file"))
{
    string[] data = line.Split(';');
    // "Name" in data[0] 
    // "Surname" in data[1] 
    // "Birthday" in data[2] 
    // "Address" in data[3]
}

Это немного проще, чем код Фредрика, но он читает файл сразу. Обычно это нормально, но вызывает проблемы для очень больших файлов.

2 голосов
/ 26 января 2011

Вот простой пример, который показывает, как анализировать файл CSV с помощью VB.NET TextFieldParser.Почему TextFieldParser?Потому что это самый полный CSV-парсер, и он уже установлен в .NET.

Также показано, как работает привязка данных в Windows Forms.Прочитайте документацию для получения дополнительной информации, это только начало.

using System;
using System.Data;
using System.Drawing;
using System.Windows.Forms;
using Microsoft.VisualBasic.FileIO;

public class Form1 : Form
{
    [STAThread]
    static void Main()
    {
        Application.EnableVisualStyles();
        Application.SetCompatibleTextRenderingDefault(false);
        Application.Run(new Form1());
    }

    DataTable records;
    BindingSource bindingSource;

    public Form1()
    {
        // Create controls
        Controls.Add(new Label { Text = "Name", AutoSize = true, Location = new Point(10, 10) });
        Controls.Add(new TextBox { Name = "Name", Location = new Point(90, 10) });
        Controls.Add(new Label { Text = "Sirname", AutoSize = true, Location = new Point(10, 40) });
        Controls.Add(new TextBox { Name = "Sirname", Location = new Point(90, 40) });
        Controls.Add(new Label { Text = "Birthday", AutoSize = true, Location = new Point(10, 70) });
        Controls.Add(new TextBox { Name = "Birthday", Location = new Point(90, 70) });
        Controls.Add(new Label { Text = "Address", AutoSize = true, Location = new Point(10, 100) });
        Controls.Add(new TextBox { Name = "Address", Location = new Point(90, 100), Size = new Size(180, 30) });
        Controls.Add(new Button { Name = "PrevRecord", Text = "<<", Location = new Point(10, 150) });
        Controls.Add(new Button { Name = "NextRecord", Text = ">>", Location = new Point(150, 150) });

        // Load data and create binding source
        records = ReadDataFromFile("Test.csv");
        bindingSource = new BindingSource(records, "");

        // Bind controls to data
        Controls["Name"].DataBindings.Add(new Binding("Text", bindingSource, "Name"));
        Controls["Sirname"].DataBindings.Add(new Binding("Text", bindingSource, "Sirname"));
        Controls["Birthday"].DataBindings.Add(new Binding("Text", bindingSource, "Birthday"));
        Controls["Address"].DataBindings.Add(new Binding("Text", bindingSource, "Address"));

        // Wire button click events
        Controls["PrevRecord"].Click += (s, e) => bindingSource.Position -= 1;
        Controls["NextRecord"].Click += (s, e) => bindingSource.Position += 1;
    }

    DataTable ReadDataFromFile(string path)
    {
        // Create and initialize a data table
        DataTable table = new DataTable();
        table.Columns.Add("Name");
        table.Columns.Add("Sirname");
        table.Columns.Add("Birthday");
        table.Columns.Add("Address");

        // Parse CSV into DataTable
        using (TextFieldParser parser = new TextFieldParser(path) { Delimiters = new String[] { ";" } })
        {
            string[] fields;
            while ((fields = parser.ReadFields()) != null)
            {
                DataRow row = table.NewRow();
                for (int n = 0; n < fields.Length; n++)
                    row[n] = fields[n];
                table.Rows.Add(row);
            }
        }

        return table;
    }
}
2 голосов
/ 26 января 2011

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

// open the file in a way so that we can read it line by line
using (Stream fileStream = File.Open("path-to-file", FileMode.Open))
using (StreamReader reader = new StreamReader(fileStream))
{
    string line = null;
    do
    {
        // get the next line from the file
        line = reader.ReadLine();
        if (line == null)
        {
            // there are no more lines; break out of the loop
            break;
        }

        // split the line on each semicolon character
        string[] parts = line.Split(';');
        // now the array contains values as such:
        // "Name" in parts[0] 
        // "Surname" in parts[1] 
        // "Birthday" in parts[2] 
        // "Address" in parts[3] 

    } while (true);
}

Кроме того, проверьте CSVReader , которыйбиблиотека, облегчающая обработку таких файлов.

0 голосов
/ 26 января 2011

В основном вам необходимо

  • Читать файл (File.ReadAllLines)
  • Создать список записей (1 запись = 1 набор имени, фамилии, дня рождения)
  • Разбор прочитанного текста и заполнение списка записями
  • Создание формы и передача полученных данных в эту форму
  • Создание собственного набора пользовательских элементов управления UserControl = для просмотра ваших данных + несколькокнопки (FW и BW)

Это довольно сложный вопрос.

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