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

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


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

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

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

Шичко Игорь
Статус: Студент
Рейтинг: 274
∙ повысить рейтинг >>
Moryarty
Статус: 9-й класс
Рейтинг: 143
∙ повысить рейтинг >>
megaloman
Статус: Практикант
Рейтинг: 45
∙ повысить рейтинг >>

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

Выпуск № 817
от 05.11.2008, 13:35

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

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

Вопрос № 149101: Подскажите, пожалуйста! Мне в макрос надо ввести переменную или цикл ?? Этот мак работает, как мне надо, но не могу ж я его 71 раз(число подразделений.) повторить. Разбиение общей ведомости на отдельные для каждого цеха Sub May() ...


Вопрос № 149.101
Подскажите, пожалуйста!
Мне в макрос надо ввести переменную или цикл ??
Этот мак работает, как мне надо, но не могу ж я его 71 раз(число подразделений.) повторить.

Разбиение общей ведомости на отдельные для каждого цеха
Sub May()


Selection.AutoFilter Field:=5, Criteria1:="ВРХЛ"
Cells.Select
Range("D2").Activate
With Selection
.VerticalAlignment = xlBottom
.WrapText = False
.Orientation = 0
.ShrinkToFit = False
.MergeCells = False
End With
Selection.Copy
Workbooks.Add
Range("A1").Select
ActiveSheet.Paste
Selection.Rows.AutoFit
Selection.Columns.AutoFit
Application.CutCopyMode = False
ActiveWorkbook.SaveAs FileName:="D:ВРХЛ.xls", FileFormat:=xlNormal, _
Password:="", WriteResPassword:="", ReadOnlyRecommended:=False, _
Crea teBackup:=False
ActiveWindow.Close
End Sub


Приложение:

Отправлен: 31.10.2008, 13:05
Вопрос задала: Iris (статус: 1-й класс)
Всего ответов: 1
Мини-форум вопроса >>> (сообщений: 0)

Отвечает: Шичко Игорь
Здравствуйте, Iris!
В Вашей ситуации можно сделать следующее:
На отдельном листе создать список подразделений и разместить их к примеру a1...a71
Далее добавляем код:

Sub May()

Dim ved As String
Dim i As Integer
Dim Sheet, Sheet_1 As Object
Set Sheet = ThisWorkbook.Sheets("Лист3") '' Лист с названиями подразделений
Set Sheet_1 = ThisWorkbook.Sheets("Лист1") ''Лист с ведомостью
i = 1
While Sheet.Range("a" + CStr(i)).Value > ""
ved = Sheet.Range("a" + CStr(i))
Sheet_1.Select
Cells.Select
Selection.AutoFilter Field:=5, Criteria1:= ved
.....

''Код Вашего макроса только изменить:
ActiveWorkbook.SaveAs FileName:="D:" & ved & ".xls", FileFormat:=xlNormal, _
Password:="", WriteResPassword:="", ReadOnlyRecommended:=False, _
...

i = i + 1
Wend

End Sub
Ответ отправил: Шичко Игорь (статус: Студент)
Ответ отправлен: 31.10.2008, 14:53

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

    Оценка за ответ: 5


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

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

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

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

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

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


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

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

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

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

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

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


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

    ∙ Версия системы: 5.10 от 5.11.2008

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

    В избранное