Последние записи
- Взаимодействие через командную строку
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
- Сравнение языков на массивах. Часть 2
- wprintf как напечатать кириллицу
- Взаимодействие через командную строку
- Сравнение языков на массивах. Часть 1
- Сравнение языков по скорости
- Чтение огромных xml-файлов
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
29th
Дек
Как закрыть папку в Excel средствами VBA без имитации нажатия клавиш?
Posted by obzor under VBA
Уважаемые знатоки VBA, есть много средств для открытия папки или файла (диалоговые окна и т. д.), но как ЗАКРЫТЬ средствами VBA ПАПКУ?
Сделал пока вот так:
Private Sub Workbook_Open()
Set objShellApp = CreateObject("Shell.Application")
objShellApp.Open ("D:\Dropbox\")
Set WshShell = CreateObject("WScript.Shell")
WshShell.SendKeys "(%{F4})" '"ALT" + "F4"
End Sub
Работает нормально, но это имитация нажатия клавиш. Неужели нет кода, закрывающего папку (.Close)?
Хотели закрыть папку, но для етого её открываете? В чем сила кунг-фу?
Откуда увереность что активной будет именно папка? Этот код, у меня например, захотел закрыть окно другого ексель файла.
что-бы не заморачиваться с закрытием, имхо, 3 варианта: 1)работа через файловый менеджер;2) создать ярлык на файл на рабочем столе; 3) открывать файл непосредственно из екселя — файл-открыть.
папка открыта до тех пор пока открыт хоть один файл, содержащийся в ней, более того — такими же открытыми будут считаться все папки по дереву каталогов до корневой
как только закрыт последний из открытых из данной папки файлов папка тут же становиться закрытой (доступной к переименованию, перемещению, удалению)
с точки зрения файловой системы папка это тот же файл, только содержимое этого файла — это другие папки и (или) файлы.
выбросьте идею закрытия папки из головы! закрывайте за собой файлы)
Если очень хочется, то что-то вроде :
Set iShell = CreateObject("Shell.Application")
iShell.Open "D:\Dropbox"
For Each iWin In iShell.Windows
If iWin.LocationName = "Dropbox" Then
'If iWin.LocationURL = "file:///D:/Dropbox" Then
iWin.Quit: Exit For
End If
Next
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)