Отправляет email-рассылки с помощью сервиса Sendsay

RFpro.ru: Пакет Microsoft Office

  Все выпуски  

RusFAQ.ru: Пакет Microsoft Office


Хостинг Портала RusFAQ.ru:
MosHoster.ru - Профессиональный хостинг на Windows 2008

РАССЫЛКИ ПОРТАЛА RUSFAQ.RU

Чемпионы рейтинга экспертов в этой рассылке

Botsman
Статус: Студент
Рейтинг: 241
∙ повысить рейтинг >>
Sheyanov Vladimir Valentinovich
Статус: Студент
Рейтинг: 153
∙ повысить рейтинг >>
Анатолий Ясень
Статус: Студент
Рейтинг: 71
∙ повысить рейтинг >>

/ КОМПЬЮТЕРЫ И ПО / Помощь пользователю ПО / Пакет Microsoft Office

Выпуск № 772
от 22.04.2009, 05:35

Администратор:Ерёмин А.А.
В рассылке:Подписчиков: 441, Экспертов: 82
В номере:Вопросов: 1, Ответов: 1

Нам важно Ваше мнение об этой рассылке.
Оценить этот выпуск рассылки >>

Вопрос № 165130: здравствуйте. Есть текстовый файл, состоящий из 60 тыс.строк. В каждую пятую строчку необходимо вставить строчку: End ^ . Как это сделать не используя копи-паст? Вариант с заменой в Winword не подходит, т.к. символ ^ считается служебным. Файл...


Вопрос № 165.130
здравствуйте.
Есть текстовый файл, состоящий из 60 тыс.строк. В каждую пятую строчку необходимо вставить строчку: End ^ .
Как это сделать не используя копи-паст? Вариант с заменой в Winword не подходит, т.к. символ ^ считается служебным. Файл примерно такого типа:

Приложение:

Отправлен: 16.04.2009, 15:41
Вопрос задала: Lekasa (статус: Посетитель)
Всего ответов: 1
Мини-форум вопроса >>> (сообщений: 6)

Отвечает: Megaloman
Здравствуйте, Lekasa!
Вот (можно загрузить!) VBS-скрипт, который решает Вашу задачу.
Сохраните текст в текстовый файл, сохраните его с расширением .vbs в Windows - кодировке (критично при именах файлов с русскими буквами)
В тексте поправьте пути к файлам.
Запускайте как любой исполнимый файл.
Код:
' Читаем исходный текстовый файл. Обрабатываем.
' Результат пишем в другой файл

In_File = "H:DDD1InputFile.txt" ' Исходный файл
Out_File = "H:DDD1OutputFile.txt" ' Изменённый файл
AddStr = "End^" ' Добавляемая подстрока

Dim FSO, Fin, Fout
Set FS O = CreateObject("Scripting.FileSystemObject")
Set Fin = FSO.OpenTextFile(In_File, 1, False)
Set Fout = FSO.CreateTextFile(Out_File, True, False)

On Error Resume Next
i = 0

Do While True
i = i + 1
If i = 5 Then
' В зависимости от потребности закомментируйте нужную строку (комментарий начинаеися с ')
Stroka = Fin.ReadLine() + AddStr ' В каждую пятую строку в конец добавляем указанную подстроку.
' Stroka = AddStr ' После каждой четвёртой строки вставляю строку с указанной подстрокой.
i = 0
Else
Stroka = Fin.ReadLine()
End If
If Err.Number <> 0 Then Exit Do
Fout.WriteLine Stroka
Loop

Fin.Close
Fout.Close

Так как я нечётко понял задачу (пытался уточнить в минифоруме), то предусмотрел 2 варианта.
Сейчас скрипт добавляет в конец каждой пято й строки заданный Вами текст.
То есть, в Вашем примере вместо пустой строки будет записано End ^.

Если закомментировать строку

' Stroka = Fin.ReadLine() + AddStr ' В каждую пятую строку в конец добавляем указанную подстроку.

и убрать комментарий состроки

Stroka = AddStr ' После каждой четвёртой строки вставляю строку с указанной подстрокой.

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

PS
Как я понимаю, в текстовом файле строка кончается символами LF и CR.
---------
Нет времени на медленные танцы
Ответ отправил: Megaloman (статус: Практикант)
Ответ отправлен: 16.04.2009, 19:17

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 247654 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!

    Оценка за ответ: 5
    Комментарий оценки:
    Спасибо за красивое решение)


    Вы имеете возможность оценить этот выпуск рассылки.
    Нам очень важно Ваше мнение!
    Оценить этот выпуск рассылки >>

    Отправить вопрос экспертам этой рассылки

    Приложение (если необходимо):

    * Код программы, выдержки из закона и т.п. дополнение к вопросу.
    Эта информация будет отображена в аналогичном окне как есть.

    Обратите внимание!
    Вопрос будет отправлен всем экспертам данной рассылки!

    Для того, чтобы отправить вопрос выбранным экспертам этой рассылки или
    экспертам другой рассылки портала RusFAQ.ru, зайдите непосредственно на RusFAQ.ru.


    Форма НЕ работает в почтовых программах The BAT! и MS Outlook (кроме версии 2003+)!
    Чтобы отправить вопрос, откройте это письмо в браузере или зайдите на сайт RusFAQ.ru.

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров >>

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2009, Портал RusFAQ.ru, Россия, Москва.
    Авторское право: ООО "Мастер-Эксперт Про"
    Техподдержка портала, тел.: +7 (926) 535-23-31
    Хостинг: "Московский хостер"
    Поддержка: "Московский дизайнер"
    Авторские права | Реклама на портале

    ∙ Версия системы: 5.13 от 01.12.2008

    Яндекс Rambler's Top100
    RusFAQ.ru | MosHoster.ru | MosDesigner.ru
    RusIRC.ru | Kalashnikoff.ru | RadioLeader.ru

    В избранное