Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/21: Рейтинг темы: голосов - 21, средняя оценка - 5.00
 Аватар для Bati4eli
617 / 17 / 8
Регистрация: 05.05.2012
Сообщений: 221
Записей в блоге: 11

Работа с файловой системой (системное название некоторых папок и работа со скрытыми документами)

16.08.2012, 14:02. Показов 4629. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет,
подскажите каким образом можно из VBA сохранить документ txt в папке "Общие документы" и задать для него свойство "скрытый" или "системный", и при этом как в дальнейшем его открыть?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.08.2012, 14:02
Ответы с готовыми решениями:

Работа с файловой системой
Скажите как реализовать команду copy file1 file2 с помощью системных функций языка С. И как отладить программу, используя инструментарий...

Работа с файловой системой
Формучане, выручайте, срочно...:cry: Нужно написать консольное приложение по работе с файловой системой. Помогите бедному студенту ...

Работа с файловой системой
У меня есть код ,в данном коде ввод и вывод происходит с помощью файлов , как создать файлы чтоб программа работала , код рабочий. import...

12
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38161 / 21096 / 4306
Регистрация: 12.02.2012
Сообщений: 34,680
Записей в блоге: 14
16.08.2012, 17:25
Это подойдет?

Visual Basic
1
2
3
4
Sub SavXls()
    ThisWorkbook.SaveAs "C:\123.xls"
    SetAttr "C:\123.xls", (vbSystem Or vbHidden)
End Sub
0
 Аватар для Bati4eli
617 / 17 / 8
Регистрация: 05.05.2012
Сообщений: 221
Записей в блоге: 11
16.08.2012, 17:46  [ТС]
Не совсем.
Нужно установить это свойство для файла TXT.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38161 / 21096 / 4306
Регистрация: 12.02.2012
Сообщений: 34,680
Записей в блоге: 14
16.08.2012, 18:00
Ну, а это:

Visual Basic
1
2
3
4
5
6
7
8
9
Sub SaveTxt()
   fo%=FreeFile
   Open Имя_папки+"\123.txt" For output as #fo%
   for i%=1 to 100
       print #fo%,i%
   Next i%
   Close #fo%
   setattr Имя_папки+"\123.txt", (vbSystem or vbHidden)
End Sub
2
15155 / 6428 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
16.08.2012, 22:48
Лучший ответ Сообщение было отмечено как решение

Решение

Нашел код для получения путей многих специальных папок:
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
28
29
30
31
32
33
34
35
36
37
Sub bb()
Dim objShell, objFSO, specialFolders$
 
'http://www.wisesoft.co.uk/scripts/vbscript_display_special_folder_locations.aspx
 
Set objShell = CreateObject("Wscript.Shell")
Set objFSO = CreateObject("Scripting.FileSystemObject")
 
With objShell
    specialFolders = "Desktop: " & .specialFolders("Desktop") & vbCrLf & _
             "MyDocuments: " & .specialFolders("MyDocuments") & vbCrLf & _
             "Startmenu: " & .specialFolders("startmenu") & vbCrLf & _
             "AllUsersDesktop: " & .specialFolders("AllUsersDesktop") & vbCrLf & _
             "AllUsersStartMenu: " & .specialFolders("AllUsersStartMenu") & vbCrLf & _
             "AllUsersPrograms: " & .specialFolders("AllUsersPrograms") & vbCrLf & _
             "AllUsersStartup: " & .specialFolders("AllUsersStartup") & vbCrLf & _
             "Favorites: " & .specialFolders("Favorites") & vbCrLf & _
             "Fonts:" & .specialFolders("Fonts") & vbCrLf & _
             "NetHood: " & .specialFolders("NetHood") & vbCrLf & _
             "PrintHood: " & .specialFolders("PrintHood") & vbCrLf & _
             "Programs: " & .specialFolders("Programs") & vbCrLf & _
             "Recent: " & .specialFolders("Recent") & vbCrLf & _
             "SendTo: " & .specialFolders("SendTo") & vbCrLf & _
             "Startup: " & .specialFolders("Startup") & vbCrLf & _
             "Templates: " & .specialFolders("Templates")
End With
 
'***** Other Special Folders *****
 
specialFolders = specialFolders & vbCrLf & _
         "Windows: " & objFSO.GetSpecialFolder(0) & vbCrLf & _
         "System32: " & objFSO.GetSpecialFolder(1) & vbCrLf & _
         "Temp:" & objFSO.GetSpecialFolder(2)
 
 
Debug.Print specialFolders
End Sub
Но вот "Общих документов" среди них нет. Возможно, потому, что расположение и название этой папки отличается в различных ОС (XP, Vista, 7, а в 2000 ее просто нет).
6
 Аватар для Bati4eli
617 / 17 / 8
Регистрация: 05.05.2012
Сообщений: 221
Записей в блоге: 11
16.08.2012, 23:02  [ТС]
Хм..
Ну вот поэтому я и хотел воспользоваться именно специальными названиями.
Спасибо, большое!
Завтра буду пробовать!
0
Эксперт MS Access
26825 / 14505 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
16.08.2012, 23:51
Environ("Public") дает расположение общей папки в вин7. Как в ХП забыл, но можно попробовать Environ(22).
1
17.08.2012, 02:20

Не по теме:

Спасибо Казанский. Напомнил мне про глобальные переменные среды через WsShell. Оказывается их там можно менять через отдельный поток и свою среду, используя Run, что в отличие от API (которая копирует среду) полноценно сделать не представлялось возможным. А то я уже отчаился это завести.

Проверка
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
Set WshShell = CreateObject("WScript.Shell")
 
WshShell.Run "setx cCheck 666", 0, True
 
For Each Var In WshShell.Environment("User")
    Debug.Print Var
Next
 
WshShell.Run "setx cCheck 777", 0, True
 
For Each Var In WshShell.Environment("User")
    Debug.Print Var
Next

0
 Аватар для dzug
695 / 236 / 18
Регистрация: 17.01.2011
Сообщений: 583
Записей в блоге: 1
17.08.2012, 13:18
Цитата Сообщение от mobile Посмотреть сообщение
Environ("Public") дает расположение общей папки в вин7. Как в ХП забыл, но можно попробовать Environ(22).
Каталог Мои документы

Visual Basic
1
Debug.Print Environ("USERPROFILE")
1
 Аватар для Bati4eli
617 / 17 / 8
Регистрация: 05.05.2012
Сообщений: 221
Записей в блоге: 11
17.08.2012, 16:01  [ТС]
Environ(23) - на 7 ке выдаёт то, что и требовалось!
На хп пока неизвестно. Даже не знаю у кого спросить (кто-то им ещё пользуется??=)

Добавлено через 1 минуту
Цитата Сообщение от Catstail Посмотреть сообщение
Sub SaveTxt()
* *fo%=FreeFile
* *Open Имя_папки+"\123.txt" For output as #fo%
* *for i%=1 to 100
* * * *print #fo%,i%
* *Next i%
* *Close #fo%
* *setattr Имя_папки+"\123.txt", (vbSystem or vbHidden)
End Sub
Работает отлично! Но файл для чтения теперь невиден!
Как быть?
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38161 / 21096 / 4306
Регистрация: 12.02.2012
Сообщений: 34,680
Записей в блоге: 14
17.08.2012, 16:21
Цитата Сообщение от Bati4eli Посмотреть сообщение
невиден!
- у свойств папки в проводнике выбери "Показывать скрытые и системные файлы". Лично я работаю в WindowsCommander-е и всегда отображаю скрытые и системные файлы.
0
 Аватар для Bati4eli
617 / 17 / 8
Регистрация: 05.05.2012
Сообщений: 221
Записей в блоге: 11
17.08.2012, 17:08  [ТС]
Как руками открыть это и так понятно.
Нужно чтоб VBA мог после этого его прочесть/ записать.
0
 Аватар для Bati4eli
617 / 17 / 8
Регистрация: 05.05.2012
Сообщений: 221
Записей в блоге: 11
20.08.2012, 09:33  [ТС]
Цитата Сообщение от Catstail Посмотреть сообщение
- у свойств папки в проводнике выбери "Показывать скрытые и системные файлы". Лично я работаю в WindowsCommander-е и всегда отображаю скрытые и системные файлы.
Уже сам разобрался..
Перед тем как в функции чтения/ записи файла проводить попытку открытия файла нужно восстановить атрибуты файла :
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
Function WriteTXT(File As String, Text As String)
Dim iline As String
 
SetAttr File, (vbNormal)  'сбрасываем атрибуты
 
Open File For Output As #121
   Write #121, Text
    ' следующая строка
    'Print #1, ""
Close #121
SetAttr File, (vbSystem Or vbHidden)  'устанавливаем атрибуты файла
End Function
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.08.2012, 09:33
Помогаю со студенческими работами здесь

Работа с файловой системой
Ребята помогите создать текстовый файл в директории, записать в него данные и затем переименовать его расширение. Добавлено через 11...

Работа с файловой системой
Здравствуйте. Сейчас перешел к изучению файлов в java и столкнулся с такой задачей: Построить программу которая может: - читает...

Работа с файловой системой
Дано задание: fOne(x): Параметры командной строки "-с" "путь1" и "путь2". Осуществляет копирование файла из пути1 в путь2. Если файл по...

Работа с файловой системой
Всем Привет! Задали задачку по C++, в итоге понял только как сделать первую часть, а со второй совсем туго. Надеюсь на вашу помощь. ...

Работа с файловой системой
Скажите пожалуйста какие в MFC есть классы для работы с файловой системой(для создания и удаления каталогов , поиска файлов, узнавания...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru