Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/55: Рейтинг темы: голосов - 55, средняя оценка - 4.71
0 / 0 / 1
Регистрация: 17.05.2012
Сообщений: 33

Чтение и запись данных из txt в Excel

03.04.2015, 11:27. Показов 10777. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет!
Подскажите, пожалуйста, как записать в Excel данные из txt-файла, если мне надо, чтобы (дальше покажу на примере):

Примерно такие данные хранятся в текстовом файле- здесь есть 2 раздела "База" и "Отдельно":

База
фрукт ДА
овощ
ягода

Отдельно
овощ;01;;
ягода;54;87;
фрукт;12;яблоко;яблсорт
фрукт;13;апельсин;аплсорт

Мне надо, что Эксель увидел, что раз в разделе БАЗА у фрукта стоит ДА, то надо записать в ячейку Эксель значения из раздела ОТДЕЛЬНО, а именно: у фруктов первые символы в 4 столбике, предшествующие "СОРТ", т.е. в итоге вот что должно быть:

ябл
апл
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.04.2015, 11:27
Ответы с готовыми решениями:

Чтение данных из txt файла и запись их в Excel
помогите пожалста. Такая вот проблемка. Есть файл (*.txt) в нём такой вот текст примерно: 11,2,333,4,51, 6,743,8,569,10, 11, и т.д....

Чтение данных с одного txt файла, запись данных во второй txt в определенную позицию
Добрый день, уважаемые форумчане! Нужна ваша помощь. Задача поставлена так: существует файл film2.txt (постараюсь его прикрепить для...

Чтение из файла 'New.txt', запись четных строк в '1.txt', а нечетных в '2.txt'
В общем все работает, но есть "НО", иначе бы не открывал тему. Содержимое исходного файла: 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2...

15
15155 / 6428 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
03.04.2015, 12:11
Приложите файл txt, максимально приближенный к реальности. Важно, что там - обычные пробелы или неразрывные, перевод строки CrLf или Lf или Cr.
0
0 / 0 / 1
Регистрация: 17.05.2012
Сообщений: 33
03.04.2015, 12:14  [ТС]
Прикладываю файл:
Вложения
Тип файла: txt Test.TXT (116 байт, 45 просмотров)
0
0 / 0 / 1
Регистрация: 17.05.2012
Сообщений: 33
03.04.2015, 12:16  [ТС]
Там обычные пробелы.. Перевода строки нету-каждый раз новая строка.
0
es geht mir gut
 Аватар для SoftIce
11274 / 4760 / 1183
Регистрация: 27.07.2011
Сообщений: 11,439
03.04.2015, 12:45
Лучший ответ Сообщение было отмечено sp-callisto как решение

Решение

Попробуйте так
Visual Basic
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
Option Compare Text
Sub MMMM()
    Dim s, s1, s2, s3() As String, i As Integer, j As Integer, k As Integer
    Open ThisWorkbook.Path & "\test.txt" For Input As #1
          s = Input(LOF(1), 1)
    Close #1
    s = Split(s, "Отдельно")
    s1 = Split(s(0), vbCrLf): s2 = Split(s(1), vbCrLf)
    For i = 0 To UBound(s1)
        If s1(i) Like "* ДА" Then
            s1(i) = Split(s1(i))(0)
            For j = 0 To UBound(s2)
             If UBound(Split(s2(j), ";")) >= 3 Then
                If Trim(s1(i)) = Trim(Split(s2(j), ";")(0)) Then
                   s2(j) = Split(s2(j), ";")(3)
                   k = k + 1: ReDim Preserve s3(1 To k): s3(k) = Replace(s2(j), "сорт", "")
                End If
             End If
            Next j
        End If
    Next i
    For i = 1 To UBound(s3)
        ThisWorkbook.Sheets(1).Cells(i, 1) = s3(i)
    Next i
End Sub
1
0 / 0 / 1
Регистрация: 17.05.2012
Сообщений: 33
03.04.2015, 12:54  [ТС]
Спасибо большое! это то, что нужно!!!
0
0 / 0 / 1
Регистрация: 17.05.2012
Сообщений: 33
04.04.2015, 14:55  [ТС]
а ещё такой вопрос.. а если искомое значение находится теперь не в 4столбике, а в седьмом, то это что именно нужно в коде поменять?
т.е. вот так выглядит:
фрукт;12;яблоко;что-то1;что-то2;что-то3;яблсорт
фрукт;13;апельсин;что-то1;что-то2;что-то3;аплсорт
0
es geht mir gut
 Аватар для SoftIce
11274 / 4760 / 1183
Регистрация: 27.07.2011
Сообщений: 11,439
04.04.2015, 15:21
Цитата Сообщение от sp-callisto Посмотреть сообщение
теперь не в 4столбике, а в седьмом
а в четвертом что ?

Просто может быть ориентироваться не на номер столбца, а на допустим, слово "сорт"?
0
0 / 0 / 1
Регистрация: 17.05.2012
Сообщений: 33
04.04.2015, 15:23  [ТС]
Цитата Сообщение от SoftIce Посмотреть сообщение
а в четвертом что ?
раньше в чётвёртом было "яблсорт" и "аплсорт". А теперь эти значения в 7 столбиках. А в чётвертом "что-то1", которое не надо выводить.
0
es geht mir gut
 Аватар для SoftIce
11274 / 4760 / 1183
Регистрация: 27.07.2011
Сообщений: 11,439
04.04.2015, 15:34
Visual Basic
1
s2(j) = Split(s2(j), ";")(3)
Вот в 15-ой строке - тройка - это четвертый столбец, исправьте 3-ку на 6-у (там нумерация столбцов с 0 идет)

Добавлено через 5 минут
И здесь
Visual Basic
1
If UBound(Split(s2(j), ";")) >= 3 Then
тоже желательно 3-ку на 6-ку исправить, чтобы ошибка не выскакивала
0
0 / 0 / 1
Регистрация: 17.05.2012
Сообщений: 33
04.04.2015, 15:45  [ТС]
Цитата Сообщение от SoftIce Посмотреть сообщение
s2(j) = Split(s2(j), ";")(3)
Спасибо! Получилось!
Только вот видимо не корректно мной был файл описан изначально(( Вот такой вопрос в связи с этим возник:
а если у меня 7 столбике не только значения типа "яблсорт", а ещё и "ууу". Т.е. у меня там не всегда слова с окончанием СОРТ. Иногда что-то другое. И это всё другое надо игнорировать. Т.е. выводить только "ябл" и "апл". Например вот такой файл:

фрукт;13;апельсин;что-то1;что-то2;что-то3;ууу
фрукт;12;яблоко;что-то1;что-то2;что-то3;яблсорт
фрукт;13;апельсин;что-то1;что-то2;что-то3;аплсорт

Сейчас получается там выбираются все значения из столбика и затирается "сорт". А как сделать так, чтобы выбирались только те значения, которые предшествуют СОРТ?

Добавлено через 5 минут
извиняюсь за ещё один вопрос.. Мне казалось, что на примере верхнего файла самостоятельно разберусь дальше, но что-то сложно(((

А если в разделе ОТДЕЛЬНО у нас фрукт стоит не первой строчкой как сейчас, а третьей- то, что надо поменять в коде? т.е. вот так:

База
фрукт ДА
овощ
ягода

Отдельно
овощ;01;;
ягода;54;87;
апельсин;13;фрукт;что-то1;что-то2;что-то3;ууу
яблоко;12;фрукт;что-то1;что-то2;что-то3;яблсорт
апельсин;13;фрукт;что-то1;что-то2;что-то3;аплсорт
0
es geht mir gut
 Аватар для SoftIce
11274 / 4760 / 1183
Регистрация: 27.07.2011
Сообщений: 11,439
04.04.2015, 16:15
Лучший ответ Сообщение было отмечено sp-callisto как решение

Решение

Вот, посмотрите, должно работать. Реагирует на присутствие слова типа"фрукт" или что-то там в любой колонке
Visual Basic
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
Option Compare Text
Sub MMMM()
    Dim s, s1, s2, s3() As String, i As Integer, j As Integer, k As Integer
    Open ThisWorkbook.Path & "\test.txt" For Input As #1
          s = Input(LOF(1), 1)
    Close #1
    s = Split(s, "Отдельно")
    s1 = Split(s(0), vbCrLf) 'в массиве содержится построчно верхняя часть текстового файла "База"
    s2 = Split(s(1), vbCrLf) 'в массиве содержится построчно нижняя часть текстового файла  "Отдельно"
    For i = 0 To UBound(s1) ' Просматриваем построчно верхнюю часть "база"
        If s1(i) Like "* ДА" Then   ' Если в строке встречается "ДА", то
            s1(i) = Split(s1(i))(0) ' то берем слово из первой колонки этой строки, например "фрукт"
            For j = 0 To UBound(s2) ' Просматриваем построчно нижнюю часть "отдельно"
              If UBound(Split(s2(j), ";")) >= 6 Then 'если в строке 7 и более колонок, то
                 If s2(j) Like "*" & s1(i) & "*" Then ' если в строке встречается наше слово ("фрукт"), то
                    s2(j) = Split(s2(j), ";")(6) ' берем слово из 7-ой колонки этой строки
                    If InStr(1, s2(j), "сорт") > 0 Then ' если в этом слове есть сочетание "сорт", то
                      k = k + 1: ReDim Preserve s3(1 To k) ' увеличиваем массив на 1
                      s3(k) = Mid(s2(j), 1, InStr(1, s2(j), "сорт") - 1) 'записываем часть слова из 7-ой колонки в массив
                    End If
                End If
             End If
            Next j
        End If
    Next i
    For i = 1 To UBound(s3)
        ThisWorkbook.Sheets(1).Cells(i, 1) = s3(i) 'Вываливаем массив на лист
    Next i
End Sub
1
0 / 0 / 1
Регистрация: 17.05.2012
Сообщений: 33
04.04.2015, 16:28  [ТС]
Цитата Сообщение от SoftIce Посмотреть сообщение
Вот, посмотрите, должно работать.
Больше спасибо за такой откомментированный и работающий код!!!
0
0 / 0 / 1
Регистрация: 17.05.2012
Сообщений: 33
06.04.2015, 14:04  [ТС]
Цитата Сообщение от SoftIce Посмотреть сообщение
Вот, посмотрите, должно работать
Подскажите, пожалуйста, как сделать так, чтобы массив вываливался не в самой первой строке, а во второй?
Пока удалось только столбец поменять, меняя второе значение у Cells:
ThisWorkbook.Sheets(1).Cells(i, 1)
0
es geht mir gut
 Аватар для SoftIce
11274 / 4760 / 1183
Регистрация: 27.07.2011
Сообщений: 11,439
06.04.2015, 14:08
Лучший ответ Сообщение было отмечено sp-callisto как решение

Решение

Visual Basic
1
2
3
    For i = 1 To UBound(s3)
        ThisWorkbook.Sheets(1).Cells(i+1, 1) = s3(i) 'начинаем со 2-ой строки первого столбца
    Next i
1
0 / 0 / 1
Регистрация: 17.05.2012
Сообщений: 33
06.04.2015, 14:14  [ТС]
Большое спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.04.2015, 14:14
Помогаю со студенческими работами здесь

Чтение данных из Excel и их запись в БД
Привет всем! Как реализовать чтение данных из Excel и их последующую запись в существующую серверную БД?

Чтение, редактирование и запись данных из MS Excel
Доброго времени суток товарищи! Программирую на VB 2010 не долго, можно сказать на "вы". Подскажите пожалуйста как сделать...

Чтение данных из Excel и запись в БД Oracle
как сделать такую программку которая бы читала данные из Excel и записывала их в БД oracle

Запись данных из Excel в txt файл. Ошибка: Bad file name or number
При выполнении макроса ругается: Bad file name or number, Run time error '52' Open "G:\feb.txt" For Output As #f <-- ругается на...

Загрузка данных из Excel (только чтение из файла) и запись в БД
Загрузка данных из Excel (только чтение из файла) и запись в БД. Вопрос: как проще открыть в ASP.Net Excel-файл (самое главное), и...


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru