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

RusFAQ.ru: Программирование на Basic / VBA


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

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

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

Megaloman
Статус: Практикант
Рейтинг: 29
∙ повысить рейтинг >>
Архипов Александр Леонидович
Статус: Практикант
Рейтинг: 15
∙ повысить рейтинг >>
Шичко Игорь
Статус: Практикант
Рейтинг: 14
∙ повысить рейтинг >>

/ КОМПЬЮТЕРЫ И ПО / Языки программирования / Basic/VBA

Выпуск № 856
от 30.01.2009, 18:35

Администратор:Калашников О.А.
В рассылке:Подписчиков: 275, Экспертов: 28
В номере:Вопросов: 1, Ответов: 1

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

Вопрос № 158725: Здравствуйте, коллеги! Собственно, вопрос пустяковый(я просто VBA не знаю совершенно, поэтому спрашиваю). Напишите, пожалуйста, как переименовываются файлы. На каком-нибудь примере. Ну вот, допустим, хочу я переименовать файл test.html в test_n...


Вопрос № 158.725
Здравствуйте, коллеги!
Собственно, вопрос пустяковый(я просто VBA не знаю совершенно, поэтому спрашиваю).
Напишите, пожалуйста, как переименовываются файлы. На каком-нибудь примере. Ну вот, допустим, хочу я переименовать файл test.html в test_new.html средствами VBA. Какой код это осуществит?
Понимаю, что вопрос примитивнейший, но рыться самому по Интернету некогда, просто друг попросил узнать. А я сам в VBA дуб полный... Абсолютно ничего не знаю.
С уважением, Товарищ Бородин
Отправлен: 25.01.2009, 18:27
Вопрос задал: Товарищ Бородин (статус: Профессионал)
Всего ответов: 1
Мини-форум вопроса >>> (сообщений: 5)

Отвечает: Megaloman
Здравствуйте, Товарищ Бородин! Если, например,

Name1 = "E:Delete est.html"
Name2 = "E:Delete est_new.html"

то собственно говоря, хватит одной строки, если без обработки ошибок:

CreateObject("Scripting.FileSystemObject").MoveFile Name1, Name2

Причем эта строка будет работать и в VBA и VBS

Если с обработкой ошибок, я бы изобразил это вот так (будет работать и в VBA и VBS):
Код:

Name1 = "E:Delete est.html"
Name2 = "E:Delete est_new.html"

On Error Resume Next

CreateObject("Scripting.FileSystemObject").MoveFile Name1, Name2

If Err.Number <> 0 Then
Msg = MsgBox("Не переименовал файл:" & vbCrLf & Name1 & vbCrLf & &q uot;в файл: " & Name2 & vbCrLf & Err.Description, vbCritical + vbOKOnly)
Else
Msg = MsgBox("Переименовал файл:" & vbCrLf & Name1 & vbCrLf & "в файл: " & Name2, vbOKOnly)
End If


а если взять вариант как у ualife, то это можно изобразить совершенно так же, за исключением одной строки (в VBS работать не будет)
Код:

Name1 = "E:Delete est.html"
Name2 = "E:Delete est_new.html"

On Error Resume Next

Name Name1 As Name2

If Err.Number <> 0 Then
Msg = MsgBox("Не переименовал файл:" & vbCrLf & Name1 & vbCrLf & "в файл: " & Name2 & vbCrLf & Err.Description, vbCritical + vbOKOnly)
Else
Msg = MsgBox("Переимен овал файл:" & vbCrLf & Name1 & vbCrLf & "в файл: " & Name2, vbOKOnly)
End If

Уже после оценки ответа решил его дополнить более эффективным, на мой взгляд, способом. Первые два способа связаны с перемещением файла (исходная и конечная папки могут отличаться), а этот способ меняет только имя файла (обратите внимание: Name2 - здесь именно имя файла без пути. Обработка ошибок осталась прежней. Работает в VBA и VBS.
Код:

Name1 = "E:Delete est.html"
Name2 = "test_new.html"

On Error Resume Next

CreateObject("Scripting.FileSystemObject").GetFile(Name1).Name = Name2

If Err.Number <> 0 Then
Msg = MsgBox("Не переименовал файл:" & vbCrLf & Name1 & vbC rLf & "в файл: " & Name2 & vbCrLf & Err.Description, vbCritical + vbOKOnly)
Else
Msg = MsgBox("Переименовал файл:" & vbCrLf & Name1 & vbCrLf & "в файл: " & Name2, vbOKOnly)
End If

А проверить можно совершенно просто:
Запустим Excel - Сервис - Макрос - Макросы - Имя макроса (например, траляля) - Создать - Вставляйте между Sub ... End Sub предложенный мной код - Run

---------
Нет времени на медленные танцы
Ответ отправил: Megaloman (статус: Практикант)
Ответ отправлен: 25.01.2009, 21:59

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 242120 на номер 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

    В избранное