Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.90/29: Рейтинг темы: голосов - 29, средняя оценка - 4.90
 Аватар для Dimasterfrom4e
9 / 8 / 0
Регистрация: 27.09.2015
Сообщений: 837

Создание папки и подпапок с названиями и числами месяцев

30.07.2016, 23:55. Показов 5888. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день.

Вопрос такой. Есть ли возможность организовать в excel макрос, который в нужной директории создаёт подпапку с названием месяца а внутри неё нужное кол-во ещё одних подпапок, в названиях которых числа месяца?

И возможно назначить этому макросу условие: допустим, наступило 1 число нового месяца, я запускаю макрос и получаю в директории новую папку с названием этого месяца, внутри которой нужное кол-во папок??))

Примера нет, т.к. только начал работать в данном направлении, пока теория....
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
30.07.2016, 23:55
Ответы с готовыми решениями:

Создание листов с названиями месяцев
Всем привет. Есть задача. Автоматическое создание листов с названиями месяцев так, чтобы новый лист вытаскивал все данные из предыдущего...

Заполнение Combobox названиями месяцев
Как можно записать в комбобокс названия месяцов считывая с листа дату формата ДД.ММ.ГГГГ?

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

15
6998 / 2896 / 555
Регистрация: 19.10.2012
Сообщений: 8,804
31.07.2016, 01:05
Можно.
Но раз в месяц можно сделать проще - копируете в нужную диреторию прошлогоднюю папку нужного месяца со всем содержимым, заходите в неё ТоталКоммандером, жмёте Ctl+B и удаляете все ненужные файлы.
1
6998 / 2896 / 555
Регистрация: 19.10.2012
Сообщений: 8,804
31.07.2016, 01:35
Лучший ответ Сообщение было отмечено Dimasterfrom4e как решение

Решение

Хотя код простой - см. файл
Файл нужно сохранить в нужной директории, затем открыть - и всё уже должно быть готово.
P.S. Но сделать один раз вручную всёж быстрее - вон сколько я код писал...
Вложения
Тип файла: xls PathCreateBook.xls (30.5 Кб, 53 просмотров)
2
4089 / 1469 / 401
Регистрация: 07.08.2013
Сообщений: 3,671
31.07.2016, 08:29
Hugo121, прости конечно но в своем екселе 2010 я не смог открыть твой файл
а так хотелось код посмотреть
1
 Аватар для Alex77755
11525 / 3812 / 683
Регистрация: 13.02.2009
Сообщений: 11,229
31.07.2016, 09:01
отключи макросы - посмотришь
2
6998 / 2896 / 555
Регистрация: 19.10.2012
Сообщений: 8,804
31.07.2016, 12:46
Код простой, но сегодня несонным глазом чуть ускорил (хотя в общем на всего максимум 31 действие и не сильно ускорение нужно но всёж...):
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
Option Explicit
 
#If Win64 Then
    #If VBA7 Then    ' Windows x64, Office 2010
        Declare PtrSafe Function MakeSureDirectoryPathExists Lib "imagehlp.dll" (ByVal lpPath As String) As LongLong
    #Else    ' Windows x64,Office 2003-2007
        Public Declare Function MakeSureDirectoryPathExists Lib "imagehlp.dll" (ByVal lpPath As String) As Long
    #End If
#Else
    #If VBA7 Then    ' Windows x86, Office 2010
        Declare PtrSafe Function MakeSureDirectoryPathExists Lib "imagehlp.dll" (ByVal lpPath As String) As Long
    #Else    ' Windows x86, Office 2003-2007
        Public Declare Function MakeSureDirectoryPathExists Lib "imagehlp.dll" (ByVal lpPath As String) As Long
    #End If
#End If
 
Sub tt()
    Dim i&, s$
 
    s = ThisWorkbook.Path & "" & Year(Now) & "" & Format(MonthName(Month(Date)), "mmmm") & ""
 
    For i = 1 To Day(DateValue("01." & Month(Now) + 1 & "." & Year(Now)) - 1)
        MakeSureDirectoryPathExists s & i & ""
    Next
 
    ThisWorkbook.Close 0
End Sub
1
 Аватар для pashulka
4139 / 2243 / 940
Регистрация: 01.12.2010
Сообщений: 4,624
31.07.2016, 13:03
Если поддаться мании сокращения, то :

Visual Basic
1
2
3
4
5
6
7
8
Private Sub Test()
    Dim i&, s$
 
    s = ThisWorkbook.Path & "\" & Format(Now, "YYYY\\MMMM\\")
    For i = 1 To Day(DateSerial(Year(Now), Month(Now) + 1, 0))
        MakeSureDirectoryPathExists s & i & "\"
    Next
End Sub
1
6998 / 2896 / 555
Регистрация: 19.10.2012
Сообщений: 8,804
31.07.2016, 13:08
pashulka, спасибо, я с этими датами вечно путаюсь, ну да и фиг с ними...
Но строка должна быть немного другой:
s & "слэш" & i & "слэш"
Не даёт форум иначе написать зараза...
1
 Аватар для pashulka
4139 / 2243 / 940
Регистрация: 01.12.2010
Сообщений: 4,624
31.07.2016, 13:27
Hugo121 , Давайте уточним для всех читающих эту тему, что проблема со слэшами есть только в Вашем сообщении.


P.S.

Visual Basic
1
2
3
4
5
6
7
Private Sub Test2()
    Dim i As Date
 
    For i = DateSerial(Year(Now), Month(Now), 1) To DateSerial(Year(Now), Month(Now) + 1, 0)
        MakeSureDirectoryPathExists ThisWorkbook.Path & Format(i, "\\YYYY\\MMMM\\D\\")
    Next
End Sub
2
6998 / 2896 / 555
Регистрация: 19.10.2012
Сообщений: 8,804
31.07.2016, 13:29
Ну может быть что только я такой избранный - ну тогда измените свой код чтоб он работал корректно. И чтоб на форуме корректно был виден, или опять я избранный?
Миниатюры
Создание папки и подпапок с названиями и числами месяцев  
1
6998 / 2896 / 555
Регистрация: 19.10.2012
Сообщений: 8,804
31.07.2016, 13:32
pashulka, я понял - это форум слэш съел, последний код отрабатывает корректно.
1
 Аватар для pashulka
4139 / 2243 / 940
Регистрация: 01.12.2010
Сообщений: 4,624
31.07.2016, 13:49
Цитата Сообщение от Hugo121 Посмотреть сообщение
или опять я избранный?
Безусловно, ибо у всех остальных слэш должен быть
Миниатюры
Создание папки и подпапок с названиями и числами месяцев  
1
6998 / 2896 / 555
Регистрация: 19.10.2012
Сообщений: 8,804
31.07.2016, 13:57
Странно, запустил ещё раз - теперь всё корретно... Не хорошо это...
1
 Аватар для Dimasterfrom4e
9 / 8 / 0
Регистрация: 27.09.2015
Сообщений: 837
31.07.2016, 14:34  [ТС]
Всем спасибо за помощь))) А если директория с годом 2016 уже создана и внутри нее создавать только месяцы с числами???)))
0
6998 / 2896 / 555
Регистрация: 19.10.2012
Сообщений: 8,804
31.07.2016, 14:36
А попробовать?
Вообще этот год - это отсебятина, Вы ведь не просили...
1
 Аватар для Dimasterfrom4e
9 / 8 / 0
Регистрация: 27.09.2015
Сообщений: 837
31.07.2016, 14:47  [ТС]
Цитата Сообщение от Hugo121 Посмотреть сообщение
А попробовать?
Обязательно ))) Спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
31.07.2016, 14:47
Помогаю со студенческими работами здесь

Создание таблички с названиями операций и их последующее действие
Подскажите пожалуйста! Как создать в экселе всплывающую табличку (при нажатии кнопки) которая будет отображать названия вариантов...

Необходимо настроить распознавание папок с именами, являющимися названиями месяцев
Доброе время суток. В общем есть на VPS Windows Server 2003, на диске которого создан каталог 2016 в нем находятся папки январь февраль...

Удаление папки и подпапок в ней
Искал по форуму, не нужного Есть код: bool Remove2(char* dir){ while (_rmdir(dir) == -1 && errno == ENOTEMPTY){ if...

Архивация папки с определенным списком подпапок
Здравствуйте. Допустим: имеется папка (А1), в которой находится куча подпапок (В1, В2, В3, В4 ...) и файлы. Необходимо заархивировать...

DotNetZip добавление папки с выбором подпапок
Всем Здравствуйте. Пробую архивировать с библиотекой DotNetZip. Есть папка с подпапками и файлами в ней лежит подпапка "temp"...


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru