Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/121: Рейтинг темы: голосов - 121, средняя оценка - 4.62
437 / 144 / 9
Регистрация: 12.01.2009
Сообщений: 678
Записей в блоге: 1

Проверить существование файла

01.07.2009, 14:15. Показов 22340. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, коллеги.
Мне нужно проверить существование файла, название которого не известно заранее. Известна только маска фала, которая задаётся приблизительно так:
Visual Basic
1
"объект_т" + MyName + ".xls"
(MyName-строковая переменная, которая принимает разные значения в зависимости от условия)
Единственное что пока пришло в голову - fileExists метод.
Как написать путь к файлу понятно, но вот как указать объект не очень.
Объясните пожалуйста. Заранее большое спасибо!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.07.2009, 14:15
Ответы с готовыми решениями:

Проверить существование файла. Проверить содержание ячейки
Уважаемые программисты я только начинаю тернистый путь, так что извините если вопросы не корректны. 1) Я в цикле открываю по очереди...

Проверить существование файла в директории
Добрый день! Вынужден обратится за помощью. Задача следующая: Имеем файл вида - X_Xyyyyyyyyyy.pdf, где X-известное нам...

Как проверить существование файла ?
Например name.xls, мне нужно чтоб макрос не останавливался, если файла не существует. Есть какая-нибудь функция, типа, exist? В книжке...

11
 Аватар для Toxa33rus
3917 / 918 / 125
Регистрация: 16.04.2009
Сообщений: 1,940
01.07.2009, 16:40
Из названия темы суть вопроса понял, а вот из описания понял что не понял. Если надо проверить есть ли файл то может так:
Visual Basic
1
2
3
4
5
6
7
8
9
10
Sub test()
res = FileExist("объект_т" + MyName + ".xls")
End Sub
 
Function FileExist(filename As String) As Boolean
    On Error Resume Next
    FileExist = Dir$(filename) <> ""
    If Err.Number <> 0 Then FileExist = False
    On Error GoTo 0
End Function
2
0 / 0 / 0
Регистрация: 11.08.2015
Сообщений: 17
28.11.2018, 12:53
Добрый день.
Помогите, что с моим кодом не так? Запускаю из Access 2003
Sub, Function, or Property not defined (Error 35)

Visual Basic
1
2
3
4
5
6
7
8
9
Sub DeleteFile1(ByVal strTarget As String)
 
   If FileExists(strTarget) Then 
     
   MsgBox ("Файл существует" & strTarget), vbInformation
Else
   MsgBox ("Файл не существует"), vbCritical
End If
End Sub
Я ее вызываю из другой функции:
Visual Basic
1
2
3
strTarget = "s:\mail\Ext1_34.mdb"
MsgBox (strTarget), vbInformation
DeleteFile1 (strTarget)
0
95 / 38 / 15
Регистрация: 02.04.2015
Сообщений: 235
28.11.2018, 13:18
Влад77, Вроде как вызывается через Call
PureBasic
1
Call DeleteFile1 (strTarget)
0
0 / 0 / 0
Регистрация: 11.08.2015
Сообщений: 17
28.11.2018, 13:50
Цитата Сообщение от Петр Аркадьевич Посмотреть сообщение
1
Call DeleteFile1 (strTarget)
Не помогает. Ошибка где то здесь "If FileExists(strTarget) Then"
0
es geht mir gut
 Аватар для SoftIce
11274 / 4760 / 1183
Регистрация: 27.07.2011
Сообщений: 11,439
28.11.2018, 14:38
Цитата Сообщение от Влад77 Посмотреть сообщение
FileExists
Это функция, её скопировали себе ?
0
0 / 0 / 0
Регистрация: 11.08.2015
Сообщений: 17
28.11.2018, 15:55
Нет, не скопировал. Если функция тогда ясно.
0
es geht mir gut
 Аватар для SoftIce
11274 / 4760 / 1183
Регистрация: 27.07.2011
Сообщений: 11,439
28.11.2018, 16:03
Цитата Сообщение от Влад77 Посмотреть сообщение
Если функция тогда ясно.
Что ясно ? Скопируйте себе эту функцию из второго сообщения .
1
1866 / 1186 / 192
Регистрация: 27.03.2009
Сообщений: 4,603
28.11.2018, 16:04
Visual Basic
1
2
3
4
strTarget = "s:\mail\Ext1_34.mdb"
If Dir(strTarget) <> "" Then
MsgBox ("Файл существует" & strTarget), vbInformation
End If
1
0 / 0 / 0
Регистрация: 11.08.2015
Сообщений: 17
28.11.2018, 16:20
Спасибо. Сделал так:
Visual Basic
1
2
3
4
5
6
7
8
Sub DeleteFile1(ByVal strTarget As String)
 
   If Not Dir(strTarget) = "" Then
      Kill (strTarget)
      MsgBox ("Старый файл удален " & strTarget), vbInformation
 
End If
End Sub
Если-бы еще можно было проверить возможность удаления файла. То-есть если нет возможности удалить. тогда написать сообщение "Освободите файл базы"
0
Заблокирован
28.11.2018, 16:29
Visual Basic
1
2
3
4
5
6
7
8
9
10
on error resume next
    Kill (strTarget)
    if err then
      MsgBox "ERROR!"
'      err.clear
'      GOTO куда_следует
    else
      MsgBox ("Старый файл удален " & strTarget), vbInformation
    endif
on error goto 0
-это вместо 4 и 5 строки.
2
0 / 0 / 0
Регистрация: 11.08.2015
Сообщений: 17
28.11.2018, 17:17
Спасибо все получилось.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.11.2018, 17:17
Помогаю со студенческими работами здесь

Как проверить существование файла в папке,если filesystemobject не распознается VBA?
вопрос такой: надо ли подключать какую-нибудь бибилиотеку для работы с файловой системой, а именно с объектом filesystemobject. или...

Проверить существование объекта
Как проверяется в vba существование объекта? Например объект selection.listobject или selection.offset(-3, 0)

Как проверить существование кнопки
Нужно удалить кнопку, которая может существовать, а может и не существовать (кнопка создается в зависимости от выбора пользователя). Каким...

Проверить переменную типа Object на существование
Допустим я создал и переменную dim j as object Set j = New Access.ApplicationВ случае какой-либо ошибки пользователь вынужден нажать...

Excel: Как проверить существование объекта?
Сабж. Для примера: Проверить есть ли комментарий у ячейки (или Range) и если есть то скопировать его в другую ячейку. ...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
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 . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru