Форум программистов, компьютерный форум, киберфорум
Visual Basic .NET
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.92/13: Рейтинг темы: голосов - 13, средняя оценка - 4.92
4 / 4 / 0
Регистрация: 17.01.2020
Сообщений: 197
1

Поиск текста в текстовом файле и добавление новой строки, если искомого текста не существует

31.12.2020, 09:51. Показов 2474. Ответов 5
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Доброго дня!
Подскажите как решить следующую задачу.
на форме текстовое поле и кнопка.
имеется так же текстовый файл формата:
31.12.2020 09:00:23|Иванов И.И.
31.12.2020 08:07:32|Петров В.С.
31.12.2020 06:27:00|Колос Г.А.
31.12.2020 06:38:10|Васин В.В.

Вводим в текстовое поле фамилию и инициалы, производим проверку есть ли искомый текст в текстовом файле, если есть, то вывести в сообщении номер строки и дату, если нет, то добавить текст в текстовый файл. текущая дата и время|ФИО
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
31.12.2020, 09:51
Ответы с готовыми решениями:

Поиск текста в одном файле и добавление строки в другой
Здравствуйте! Помогите, пожалуйста, реализовать задачу: Есть 2 файла. В одном надо читать и...

Поиск заданного текста (части строки) в текстовом файле и вывод результата построчно в другой текстовый файл
Здравствуйте! Есть файл 1.txt вида: <img align="middle" src="client.gif"> <a...

Как ускорить поиск текста в текстовом файле?
День добрый! У меня есть порядка 200 текстовых файлов. Размер от 300 до 900 кб. Требуется...

Добавление текста в Memo с новой строки
Здравствуйте! Как сделать что бы текст, который печатается в компоненте Edit, доходя до конца своей...

5
822 / 637 / 151
Регистрация: 27.01.2019
Сообщений: 1,355
31.12.2020, 13:15 2
KwaZZi, Как то так
VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
Public Class Form1
    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
        Dim Pu As String = "T1.txt" 'путь и имя вашего .тхт файла 
        Dim Arr(), A, d(2) As String
        Dim Col As New List(Of String)
 
        Try
            If IO.File.Exists(Pu) Then
                Arr = IO.File.ReadAllLines(Pu, System.Text.Encoding.Default) ' считываем файл в массив
            Else
                MsgBox("Файла не существует")
                Exit Sub
            End If
            If TextBox1.Text = "" Then
                MsgBox("Введите ФИО")
                Exit Sub
            End If
            A = TextBox1.Text
            For i = 0 To UBound(Arr)
                d = Strings.Split(Arr(i), "|")
                If A = d(1) Then
                    MsgBox(i + 1 & ")  " & d(0)) ' если запись есть выводим сообщение
                    Exit Sub
                End If
            Next
            'если нет записи ,добавляем ее
            TextBox1.Clear()
            TextBox1.Text = Now & "|" & A
            For Each A2 As String In Arr
                Col.Add(A2) 'заполняем коллекцию из массива
            Next
            Col.Add(TextBox1.Text) 'добавляем в коллекцию новую запись
            IO.File.WriteAllLines(Pu, Col, System.Text.Encoding.Default) 'перезаписываем файл
        Catch ex As Exception
            MsgBox(ex.ToString)
        End Try
    End Sub
End Class
Ваш файл во вложении.
Вложения
Тип файла: txt T1.txt (128 байт, 4 просмотров)
2
4651 / 3608 / 854
Регистрация: 02.02.2013
Сообщений: 3,487
Записей в блоге: 2
31.12.2020, 14:21 3
KwaZZi, все зависит от размеров текстового файла. Если файл небольшой, то выбор алгоритма не принципиален, например
VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
Private Sub Button2_Click(sender As System.Object, e As System.EventArgs) Handles Button2.Click
    findRow(TextBox1.Text, Path.Combine(Application.StartupPath, "tst.txt"))
End Sub
Private Sub findRow(ByVal strData As String, ByVal fPath As String)
    Dim rws() As String = File.ReadAllLines(fPath, System.Text.Encoding.UTF8)
    Dim frw = From r In rws Where r = strData Select Array.IndexOf(rws, r)
    If frw.Count = 0 Then
        File.AppendAllLines(fPath, {strData}, System.Text.Encoding.UTF8)
    Else
        MsgBox(strData & " RowIndex=" & frw(0).ToString)
    End If
End Sub
1
2755 / 2763 / 545
Регистрация: 17.02.2019
Сообщений: 4,564
31.12.2020, 15:26 4
KwaZZi, ну как пример
VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
Public Class Form1
    Dim MassivText(), MassivFIO() As String
 
    Private Sub Form1_Load(sender As System.Object, e As System.EventArgs) Handles MyBase.Load
        ' Это так если надо чтоб не изменяли textBox2 ручками когда фокус на нем
        'TextBox2.ReadOnly = True
        'TextBox2.BackColor = Color.White
        'TextBox2.ForeColor = Color.Black
        Try
            TextBox2.AppendText(My.Computer.FileSystem.ReadAllText(Application.StartupPath & "\TextFile.txt", System.Text.Encoding.Default))
            FIO()
        Catch ex As Exception
            MsgBox("Файла НЕТ")
        End Try
    End Sub
 
    Private Sub Button1_Click(sender As System.Object, e As System.EventArgs) Handles Button1.Click
        If MassivFIO.Contains(TextBox1.Text) Then _
            MsgBox("У вас есть запись в строке " & Array.IndexOf(MassivFIO, TextBox1.Text) + 1 & _
                " " & MassivText(Array.IndexOf(MassivFIO, TextBox1.Text))) : Exit Sub
 
        TextBox2.AppendText(Now.ToShortDateString & " " & Now.ToLongTimeString & "|" & TextBox1.Text & vbCrLf)
        IO.File.WriteAllText(Application.StartupPath & "\TextFile.txt", TextBox2.Text, System.Text.Encoding.Default)
        FIO()
    End Sub
    Private Sub FIO()
        If UBound(MassivText) > 0 Then
            MassivText = IO.File.ReadAllLines(Application.StartupPath & "\TextFile.txt", System.Text.Encoding.Default)
            ReDim MassivFIO(UBound(MassivText))
            For a = 0 To UBound(MassivText)
                Dim FIO() As String = Split(MassivText(a), "|")
                MassivFIO(a) = FIO(1)
            Next
        End If
    End Sub
End Class
1
4651 / 3608 / 854
Регистрация: 02.02.2013
Сообщений: 3,487
Записей в блоге: 2
31.12.2020, 15:52 5
Лучший ответ Сообщение было отмечено KwaZZi как решение

Решение

Виноват, не внимательно прочитал вопрос. Исправьте.
VB.NET
1
2
3
4
5
6
7
8
9
Private Sub findRow(ByVal strData As String, ByVal fPath As String)
    Dim rws() As String = File.ReadAllLines(fPath, System.Text.Encoding.UTF8)
    Dim frw = From r In rws Where r.Contains(strData) Select Array.IndexOf(rws, r)
    If frw.Count = 0 Then
        File.AppendAllLines(fPath, {Now.ToString & "|" & strData}, System.Text.Encoding.UTF8)
    Else
        MsgBox(rws(frw(0)) & " RowIndex=" & frw(0).ToString)
    End If
End Sub
3
2755 / 2763 / 545
Регистрация: 17.02.2019
Сообщений: 4,564
31.12.2020, 16:01 6
Чет я поторопился не проверил. так наверное вернее.
VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
Public Class Form1
    Dim MassivText(), MassivFIO() As String
 
    Private Sub Form1_Load(sender As System.Object, e As System.EventArgs) Handles MyBase.Load
        ' Это так если надо чтоб не изменяли textBox2 ручками когда фокус на нем
        'TextBox2.ReadOnly = True
        'TextBox2.BackColor = Color.White
        'TextBox2.ForeColor = Color.Black
        Try
            MassivText = IO.File.ReadAllLines(Application.StartupPath & "\TextFile.txt", System.Text.Encoding.Default)
            TextBox2.AppendText(My.Computer.FileSystem.ReadAllText(Application.StartupPath & "\TextFile.txt", System.Text.Encoding.Default))
            FIO()
        Catch ex As Exception
            MsgBox("Файла НЕТ")
        End Try
    End Sub
 
    Private Sub Button1_Click(sender As System.Object, e As System.EventArgs) Handles Button1.Click
        If TextBox1.Text = "" Then Exit Sub
        If MassivFIO.Contains(TextBox1.Text) Then _
            MsgBox("У вас есть запись в строке " & Array.IndexOf(MassivFIO, TextBox1.Text) + 1 & _
                " " & MassivText(Array.IndexOf(MassivFIO, TextBox1.Text))) : Exit Sub
 
        TextBox2.AppendText(Now.ToShortDateString & " " & Now.ToLongTimeString & "|" & TextBox1.Text & vbCrLf)
        IO.File.WriteAllText(Application.StartupPath & "\TextFile.txt", TextBox2.Text, System.Text.Encoding.Default)
        MassivText = IO.File.ReadAllLines(Application.StartupPath & "\TextFile.txt", System.Text.Encoding.Default)
        FIO()
    End Sub
    Private Sub FIO()
        If UBound(MassivText).ToString > 0 Then
            ReDim MassivFIO(UBound(MassivText))
            For a = 0 To UBound(MassivText)
                Dim FIO() As String = Split(MassivText(a), "|")
                MassivFIO(a) = FIO(1)
            Next
        End If
    End Sub
End Class
2
31.12.2020, 16:01
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
31.12.2020, 16:01
Помогаю со студенческими работами здесь

Добавление текста с новой строки в TextBox
Как добавить текст, с новой строки? Команда: textBox1 += "Текст1" + ...

Вывод текста с n-строки по m-строку в текстовом файле
Вывод текста с n-стро-и по m-стро-у в текстовом файле

Обработка фразы (строки текста), находящейся в текстовом файле
Составить алгоритм и программу обработки фразы (строки текста), находящемся в текстовом файле...

Поиск в текстовом файле слова и вывод блока текста, в котором оно встретилось
Здравствуйте! Подскажите пожалуйста как будет выглядеть код мне нужно реализовать поиск по txt...

Составить алгоритм и программу обработки фразы (строки текста), находящемся в текстовом файле Input.txt.
люди плизз решите задачу на паскале Задание Составить алгоритм и программу обработки фразы...

Как очистить текст от лишнего текста с обеих сторон от искомого текста?
С сайта*парсится*текст,*имеющий несколько*вариантов: Вар 1...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru