Функция НайтиФайлы() в каталоге netshare на Linux - обход ошибки работы

25.10.18

Разработка - Универсальные функции

Решение проблемы применения функции НайтиФайлы() в каталоге с netshare на Linux-сервере - не работает поиск файлов по указанной маске (шаблону)

Предыстория: у клиента на ЖД терминале сервер работает под ОС Linux. Компьютер ЖД весовой при взвешивании вагонов сохраняет локально фотографии, но сервер по локальной сети через netshare имеет возможность получить эти файлы по обычному пути. При необходимости вывести фотографии за определенный момент времени необходимо выполнить поиск файлов по шаблону имени, которое как раз составляется по дате и времени, использование стандартной функции НайтиФайлы() с Windows проблем не вызвало - все ищется, но под Linux НайтиФайлы() с поиском по маске не работает - результат пустой, ищет только по полному четкому имени конкретного файла . Решение было найдено через использование вызова команды Linux "find" через командную оболочку (ЗапуститьПриложение) и вывода результатов поиска (текст с перечнем имен найденных файлов построчно) в текстовый файл с последующим его чтением.

ИмяФайлаСписка = ПолучитьИмяВременногоФайла("txt");
Команда = СтрШаблон("find %1/%2*.jpg > %3", ИмяКаталога, ШаблонВремени, ИмяФайлаСписка);
ЗапуститьПриложение(Команда,, Истина);
	
Файл = Новый Файл(ИмяФайлаСписка);
Если НЕ Файл.Существует() Тогда
    Сообщить("Файлы не обнаружены");
	Возврат;
КонецЕсли; 
	
НайденныеФайлы = Новый Массив;
Чтение = Новый ЧтениеТекста(ИмяФайлаСписка);
ПутьКФайлу = Чтение.ПрочитатьСтроку();
Пока ЗначениеЗаполнено(ПутьКФайлу) цикл
			
	НайденныеФайлы.Добавить(ПутьКФайлу);
	ПутьКФайлу = Чтение.ПрочитатьСтроку();
		
КонецЦикла;

Чтение.Закрыть();

Быть может, такая проблема возникала еще у кого-то. С причиной подобного бага конкретно на данном дистрибутиве Linux не разбирался, возможно дело именно в использовании netshare.

Вступайте в нашу телеграмм-группу Инфостарт

Linux netshare НайтиФайлы

См. также

Загрузка и выгрузка в Excel Универсальные функции Программист 1С:Предприятие 8 Россия Бесплатно (free)

Описанный ниже подход позволяет в три шага заполнять формулы в Excel файлы, вне зависимости от ОС сервера (MS Windows Server или Linux). Подход подразумевает отказ от работы с COM-объектом в пользу работы через "объектную модель документа" (DOM).

30.10.2025    2723    Abysswalker    7    

41

Универсальные функции Работа с интерфейсом Программист 1С:Предприятие 8 Бесплатно (free)

Порой необходимо временно отключить расширение 1С, не удаляя его, чтобы не потерять данные. Но в этом случае при каждом запуске всем будет лезть уведомление о неактивном расширении, хотя очевидно, это техническая информация, которой не стоит лишний раз пугать пользователей.

14.05.2025    5744    DeerCven    15    

57

Универсальные функции Программист 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Благодаря этим пяти строчкам можно больше не заморачиваться с загрузкой из внешних файлов. Пользуюсь везде, всегда и постоянно.

21.05.2024    47139    dimanich70    83    

167

Универсальные функции Программист 1С:Предприятие 8 1C:Бухгалтерия Абонемент ($m)

Задача: вставить картинку из буфера обмена на форму средствами платформы 1С.

1 стартмани

18.03.2024    7050    6    John_d    13    

59

Универсальные функции Программист Стажер 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Пришлось помучиться с GUID-ами немного, решил поделиться опытом, мало ли кому пригодится.

12.02.2024    58493    atdonya    31    

69

Универсальные функции Программист 1С:Предприятие 8 Бесплатно (free)

На заключительных этапах, когда идет отладка или доработка интерфейса, необходимо много раз переоткрыть внешний объект. Вот один из способов автоматизации этого.

30.11.2023    8783    ke.92@mail.ru    17    

68
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Armando 1402 19.09.18 22:54 Сейчас в теме
Не бага, а фича. https://its.1c.ru/db/v83doc#bookmark:dev:TI000001209
"Еще одной особенностью ОС Linux является то, что в ней нет возможности обращаться к сетевым ресурсам, используя UNC-нотацию (в этом случае адрес имеет следующий вид: \\server\folder\folder\file.ext). Поэтому, при необходимости использовать какой-либо внешний сетевой ресурс, его необходимо предварительно смонтировать на корневую файловую систему."
drmaxart; +1 Ответить
2. albertik88 11 17.07.20 06:23 Сейчас в теме
Добрый день! Столкнулся с такой же проблемой, нужно из 1с под линуксом открыть файл с сервера, пытаюсь реализовать по аналогии с вашим решением, но у меня получается что переменная "ПутьКФайлу" получается пустой, хотя нужный файл присутствует на сервере, и не понятна ваша команда

Команда = СтрШаблон("find %1/%2*.jpg > %3", ИмяКаталога, ШаблонВремени, ИмяФайлаСписка);

а именно "> %3" - могли бы пояснить что это?

вот кусок моего кода:

ПутьКТому = "smb://192.168.1.252/up_doc";
					
ИмяФайлаСписка = ПолучитьИмяВременногоФайла("txt");
					
Команда = СтрШаблон("find %1 -name %2* > %3", ПутьКТому, ИмяФайлаВТоме, ИмяФайлаСписка);
ЗапуститьПриложение(Команда,, Истина);
					
Файл = Новый Файл(ИмяФайлаСписка);
Если НЕ Файл.Существует() Тогда
    Сообщить("Файлы не обнаружены");
Иначе
    НайденныеФайлы = Новый Массив;
    Чтение = Новый ЧтениеТекста(ИмяФайлаСписка);
    ПутьКФайлу = Чтение.ПрочитатьСтроку();
    Пока ЗначениеЗаполнено(ПутьКФайлу) цикл
    	    НайденныеФайлы.Добавить(ПутьКФайлу);
            ПутьКФайлу = Чтение.ПрочитатьСтроку();
    КонецЦикла;

    Чтение.Закрыть();
    КонецЕсли;
Показать
3. drmaxart 154 08.08.20 08:39 Сейчас в теме
(2) Добрый день! "> %3" в скрипте означает перенаправление вывода в указанный файл. Так бы список найденных файлов вывелся в командную строку, а при этой конструкции он выводится в файл, который мы уже из 1С можем прочитать
Для отправки сообщения требуется регистрация/авторизация