Как сохранить любой табличный документ в excel так, чтобы даты сохранились как даты?

19.07.23

Интеграция - Загрузка и выгрузка в Excel

Как сохранить любой табличный документ 1С (отчет) в excel так, чтобы дата была датой, а не строкой? Я заинтересовался этим вопросом по долгу службы. Выяснилось, что примерно никак))) Все, можно расходиться! Но есть лайфхаки и самый из них, по моему скромному мнению, это сохранить штатными средствами, а затем в получившемся файле сделать автозамену точки на точку)))

Скачать исходный код

Наименование Файл Версия Размер
Расширение для не типовой (общий модуль, картинка и форма отчета для примера с кнопкой):
.cfe 13,21Kb
1
.cfe 13,21Kb 1 Скачать
Расширение для ЕРП (общий модуль, картинка и форма отчета для примера с кнопкой):
.cfe 39,37Kb
0
.cfe 39,37Kb Скачать

Как сохранить любой табличный документ 1с в excel так, что бы дата была датой, а не строкой?

Я заинтересовался этим вопросом по долгу службы. Выяснилось, что никак.))) Все, можно расходиться. Но есть лайфхаки и самый из них, по моему скромному мнению, удачный это:

  • Сохраняем отчет стандартным способом в excel.

 

 

  •  Открываем файл и видим. что дата хранится в формате строки:

 

 

  • Жмем заменить (при условии что дата разделена «.» (точкой)) и меняем «.» на «.» везде.

 

         

 

  • Все готово. Вы только что не меняя файл изменили его.)))

 

 

Если дата у вас разделена «\» (слешем),  нет  проблем проведите замену «\» на «\»

Если же ваши пользователи такие же требовательные, как и мои, то тоже не вижу проблемы.

  • Создаем отдельную команду в форме отчета.

 

 

  • В коде этой команды добавляем диалог выбора файла, далее его сохранение в формате excel.
&НаКлиенте
Процедура ВыгрузитьВЁксель(Команда)
	
	ВыгрузитьВЁксельОбщая(Результат, "Имя_Отчета_");
	    
КонецПроцедуры

&НаКлиенте
Асинх Процедура ВыгрузитьВЁксельОбщая(аРезультат, аИмяФайлаБаза) Экспорт
	
	лДиалог = Новый ДиалогВыбораФайла(РежимДиалогаВыбораФайла.Сохранение);
	лДиалог.Фильтр="Файлы Excel(2007-2010)|*.xlsx";
	лДиалог.МножественныйВыбор = Ложь;
	лДиалог.ПолноеИмяФайла = аИмяФайлаБаза; 
	лОтвет = Ждать лДиалог.ВыбратьАсинх();
	Если лОтвет=Неопределено Тогда
		Возврат;
	КонецЕсли;
	лИмяФайла = лОтвет[0];
	лСрРаПараметры = Новый Структура;
	лСрРаПараметры.Вставить("ТекРезультат", аРезультат);
	лСрРаПараметры.Вставить("ИмяФайла",лИмяФайла);
	лОповещениеЗавершение = Новый ОписаниеОповещения("ВыборФайлаДляСохраненияЗавершение", ЭтотОбъект, лСрРаПараметры);
 	аРезультат.НачатьЗапись(лОповещениеЗавершение, лИмяФайла, ТипФайлаТабличногоДокумента.XLSX);
	
КонецПроцедуры

 

После этого программно открываем, только что созданный файл и программно меняем в нем «.» (точку) на «.» (точку) или соответственно «\» на «\»

Для этого к каждой области применяем:

Replace(".", ".", 2) или Replace("\", "\", 2)

После чего сохраняем и закрываем этот файл.

&НаКлиенте
Процедура ВыборФайлаДляСохраненияЗавершение(аЗаписьУспешна, аДопПараметры) Экспорт
	
	Если Не аЗаписьУспешна Тогда
		Сообщить(СтрШаблон("File isn'n saved! %1", ОбработкаОшибок.ПодробноеПредставлениеОшибки(ИнформацияОбОшибке()))); 
	КонецЕсли;
	лИмяФайла			= аДопПараметры.ИмяФайла;
	лРезультат			= аДопПараметры.ТекРезультат;
	лСтрок				= лРезультат.ВысотаТаблицы; 
	ПоследняяКолонка	= лРезультат.ШиринаТаблицы;
	Попытка
		лЕксель = Новый COMОбъект("Excel.Application");
		лЕксель.DisplayAlerts = 0;    
	Исключение
		Сообщить(СтрШаблон("Excel error: %1", ОбработкаОшибок.ПодробноеПредставлениеОшибки(ИнформацияОбОшибке())));
		Возврат;
	КонецПопытки; 
	лЕксельКнига = лЕксель.WorkBooks.Open(лИмяФайла);
	лЕксельЛист = лЕксельКнига.Worksheets(1);
	Для лчТекНомерКолонки = 1 По ПоследняяКолонка Цикл
		лЕксельОбласть =  лЕксельЛист.Range(лЕксельЛист.Cells(1,лчТекНомерКолонки), лЕксельЛист.Cells(лСтрок+1,лчТекНомерКолонки));
		лЕксельОбласть.Replace(".", ".", 2); 
	КонецЦикла;
	Попытка
		лЕксельКнига.SaveAs(лИмяФайла,51); 
	Исключение
		Сообщить(СтрШаблон("File isn'n saved! %1", ОбработкаОшибок.ПодробноеПредставлениеОшибки(ИнформацияОбОшибке()))); 
		лЕксель.Quit();
		Возврат;
	КонецПопытки;
	Сообщить(СтрШаблон("File saved: %1", лИмяФайла));
	лЕксель.Quit();

КонецПроцедуры

Все готово.

Если лень все это писать, скачивайте мой код в виде расширения.

Он состоит:

1. Общий модуль "Ёкс_Отчеты_Клиент" - основной код

2. Картинка - для кнопочки выгрузки в excel

3. Форма одного из отчетов для примера:

 В форме добавлена команда и ее код и кнопка для отображения на форме.

Тестировал на платформе 8.3 (8.3.21.1709).

расширение сохранения табличного документа в excel дата остается датой а не как при стоковом сохранении превращается в строку.

См. также

Загрузка номенклатуры из Excel в УТ11, КА 2, ERP 2, Розница 2. Дополнительные реквизиты и сведения, характеристики, картинки, цены, остатки

Загрузка и выгрузка в Excel Розничная торговля Логистика, склад и ТМЦ Ценообразование, анализ цен Прайсы Платформа 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Розница 2 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Управленческий учет Платные (руб)

Загрузка из файлов xls, xlsx, ods, csv, mxl в УТ11, КА 2, ERP 2, Розница 2. Задействованы все возможности конфигурации - заполнение реквизитов номенклатуры, дополнительных реквизитов и сведений, характеристики, доп.реквизиты и сведения характеристик. Дополнительные обработки для расширения возможностей.

10560 руб.

29.10.2014    212252    630    526    

446

Загрузка номенклатуры c картинками (несколько потоков одновременно) и сопутствующими данными в базу и любые документы из yml, xls, xlsx, xlsm, ods, ots, csv для УТ 10.3, УТ 11 (все), БП 3, КА 2, ERP 2, УНФ 1.6/3.0, Розница 2

Загрузка и выгрузка в Excel Логистика, склад и ТМЦ Ценообразование, анализ цен Файловый обмен (TXT, XML, DBF), FTP Платформа 1С v8.3 1С:Бухгалтерия 2.0 1С:Управление торговлей 10 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Платные (руб)

Эволюция не стоит на месте - новая удобная версия функциональной обработки для Вашего бизнеса! Что же Вы получаете? Удобный и интуитивно понятный интерфейс с 3-мя этапами работы. 2 режима - автоматический и ручной. Чтение XLSX, XLSM, CSV, XML/YML форматов без офиса, на любом сервере! Визуальное связывание колонок файла и реквизитов простым перетаскиванием колонок. Создание или обновление номенклатуры с иерархией, характеристик, доп. реквизитов, упаковок, загрузка практически неограниченного количества картинок на одну номенклатуру (с возможностью загрузки в несколько потоков одновременно), с хранением в томах или в базе. Загрузка номенклатуры поставщиков или поиск по их данным номенклатуры. Загрузка доп. реквизитов в характеристики. Загрузка штрихкодов с генерацией новых. Создание элементов справочников и ПВХ "на лету" для выбранных реквизитов. (Обновление от 09.04.2024, версия 9.9 - 9.10)

14400 руб.

20.11.2015    152040    368    376    

503

Маркетплейсный загрузчик для 12-ти маркетплейсов в 1С:БП 3, УТ 11, КА 2, ERP, УНФ

Загрузка и выгрузка в Excel Маркетплейсы Платформа 1С v8.3 Бухгалтерский учет 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Бухгалтерский учет Управленческий учет Платные (руб)

Реальный помощник, с помощью которого Вы сделаете необходимые документы для Wildberries, OZON, ЯндексМаркет, Мегамаркет, Aliexpress, "Детский мир", Казань-Экспресс, "Леруа Мерлен", ЭНФАНТА (Акушерство), ЛаМода, Летуаль, "Твой дом" в документы "Отчет комиссионера (агента) о продажах" и другие, может работать в "Бухгалтерия 3", "Бухгалтерия 3 КОРП", УТ 11, УНФ, КА 2, ERP. Возможность подключить любые маркетплейсы. Анализ продаж ОЗОН. 30 дней БЕСПЛАТНОГО пользования!

1800 руб.

12.08.2021    32576    252    65    

126

SALE! 20%

Загрузка документов и номенклатуры из Excel в 1С "одним нажатием": УПД, ТОРГ-12, отчеты маркетплейсов, заказы, счета, прайсы

Загрузка и выгрузка в Excel Оптовая торговля Платформа 1С v8.3 Управляемые формы Платформа 1C v8.2 Конфигурации 1cv8 1С:Комплексная автоматизация 1.х 1С:Бухгалтерия 2.0 1С:Управление торговлей 10 1С:Розница 2 1С:Управление производственным предприятием 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Бухгалтерский учет Управленческий учет Платные (руб)

Универсальная обработка для загрузки документов из Excel в 1С. Не требует указания параметров (номера колонок, номер первой строки таблицы и т.д.) и предварительной настройки. Просто выбираете файл Excel, документ 1С и нажимаете кнопку "Загрузить". Обработка сама находит таблицу в файле Excel, необходимые для загрузки данные в ней (номенклатура, количество, НДС, цена, сумма) и загружает ее в 1С. Вместе с номенклатурой может найти контрагента, номер и дату документа, штрих-коды, серии ГТД, страну и т.д. Распознает документы ЛЮБОЙ ФОРМЫ (УПД, ТОРГ-12, заказ, отчет комиссионера и т.д.). Не требует MS Office. Для поиска таблиц используются методы эвристического поиска. Загружает только то, что нужно, т.е. пропускает повторы шапки таблицы, заголовки, промежуточные итоги, подписи и т.д. Содержит модуль работы с электронной почтой и api-загрузчик отчетов о продажах маркетплейсов.

5000 4000 руб.

09.11.2016    217201    935    886    

946

Загрузка данных отчета о реализации товаров из Excel файла СберМегаМаркет

Загрузка и выгрузка в Excel Маркетплейсы Платформа 1С v8.3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Управление нашей фирмой 3.0 Бухгалтерский учет Управленческий учет Платные (руб)

Загрузка данных отчета о реализации товаров из сервиса СберМегаМаркет для конфигурации: Бухгалтерия предприятия, редакция 3.0; Управление торговлей, редакция 11 и Управление нашей фирмой, редакция 3.0 в документ "Отчет комиссионера (агента) о продажах".

4800 руб.

07.06.2022    15469    83    0    

64

SALE! 30%

Распознавание и загрузка сканов в 1С "одним нажатием": УПД, ТОРГ-12, накладные, счета, номенклатура, заказы и т.д.

Загрузка и выгрузка в Excel Документооборот и делопроизводство (СЭД) Учет документов Распознавание документов и образов Управляемые формы 1С:Комплексная автоматизация 1.х 1С:Бухгалтерия 2.0 1С:Управление торговлей 10 1С:Розница 2 1С:Управление производственным предприятием 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Управление холдингом 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Бухгалтерский учет Управленческий учет Платные (руб)

Универсальная программа для распознавания ЛЮБЫХ СКАНОВ ИЛИ ФОТО ТОВАРНЫХ ДОКУМЕНТОВ в 1С. Не требует указания параметров и предварительной настройки. Просто выбираете файл (PDF, JPG, DOC, XLS, HTML и т.д.) выбираете документ 1С и нажимаете кнопку "Распознать и загрузить".

6000 5520 руб.

04.06.2019    102397    298    173    

314
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. SlavaKron 19.07.23 12:59 Сейчас в теме
Код:
Для лчТекНомерКолонки = 1 По ПоследняяКолонка Цикл
	лЕксельОбласть =  лЕксельЛист.Range(лЕксельЛист.Cells(1,лчТекНомерКолонки), лЕксельЛист.Cells(лСтрок+1,лчТекНомерКолонки));
	лЕксельОбласть.Replace(".", ".", 2); 
КонецЦикла;
можно заменить на
лЕксельЛист.Cells.Replace(".", ".", 2);
Zlohobbit; TimurD; +2 Ответить
2. vetka07 25.07.23 09:30 Сейчас в теме
Добрый день!

Можно гораздо проще.
Открываем MS Excel, выделяем область с датами и см. скрин.

Далее нажимаем "Готово" и все. :)
Прикрепленные файлы:
3. Zlohobbit 250 25.07.23 11:20 Сейчас в теме
(2) Если ничего не путаю то там только по одной колонке, а не как в моем варианте всю таблицу сразу! Вот что мне выдал excel при попытке сразу со всей таблицей это проделать: (смотри прикрепленную картинку)
Кроме того заменить точку на точку имхо проще чем форматировать строку в дату. Ну а так на вкус и цвет у всех фломастеры разные.)))
Прикрепленные файлы:
4. Archer161 30.03.24 17:10 Сейчас в теме
Спасибо тебе огромное, добрый человек, кучу времени сэкономил! Я тоже что только не пробовал, а решение только в автозамене)
Оставьте свое сообщение