Перевод различных Строка (Даты) в тип Дата() … предлагаю алгоритм…(версия_2)!

29.01.08

Разработка - Механизмы платформы 1С

В моей повседневной деятельности, программиста 1С, часто приходится переводить различные данные из xls и txt в 1С и приводить текстовые строки содержащие «Дату» типа «02.02.2007» или «02\02\2007» или « 02 02 2007» или «2007.02.02» или «02.02.07» и другие варианты … к значению типаДата – ‘2007.02.02’…

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Бесплатно
ПереводСтрокаВтипДата
.1201263769 5,68Kb
344
344 Скачать бесплатно
ПереводСтрокаВтипДата_02
.1201613675 5,52Kb
226
226 Скачать бесплатно
Решил написать универсальный код преобразования… Пробовал различные варианты… остановился на том который в обработке… в файле для скачивания… Вкратце: всю строку «загоняю» в массив при этом отсеиваю символы не («0123456789» ИЛИ «символы_разделения_в_дате»)… Далее по символам «символы_разделения_в_дате» делю массив на три значения д-м-г «кладу» в списокЗначений и возвращаю …

Интересно мнение всех кому эта проблема интересна…

В файле для скачивания 1. внешний отчет для 1С 8.0 и 2.алгоритм для всех в тхт

Во второй версии (ПереводСтрокаВтипДата_02):
написан алгоритм позволяющий вытащить дату из любой строки: например:

СтрокаДата = " апывп -.чм.31/Декабря.2007г. ";
СтрокаДата = " апывп -.чм.31/06.2007г. ";

программа выведет:

строка1 31 строка2 06 строка3 2007

прошу, кому задача интересна выразить своё мнение и критику...


См. также

Механизмы платформы 1С Программист Стажер Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Эта небольшая статья - некоторого рода шпаргалка по файловым потокам: как и зачем с ними работать, какие преимущества это дает.

23.06.2024    7443    bayselonarrend    20    

154

Механизмы платформы 1С Программист Стажер Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Пример использования «Сервисов интеграции» без подключения к Шине и без обменов.

13.03.2024    5942    dsdred    16    

80

Механизмы платформы 1С Программист Стажер Платформа 1С v8.3 Бесплатно (free)

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

24.01.2024    17663    YA_418728146    26    

71

Перенос данных 1C Механизмы платформы 1С Системный администратор Программист Стажер Платформа 1С v8.3 Бесплатно (free)

Вы все еще регистрируете изменения только на Планах обмена и Регистрах сведений?

11.12.2023    11221    dsdred    44    

130

Механизмы платформы 1С Программист Бесплатно (free)

Язык программирования 1С содержит много нюансов и особенностей, которые могут приводить к неожиданным для разработчика результатам. Сталкиваясь с ними, программист начинает лучше понимать логику платформы, а значит, быстрее выявлять ошибки и видеть потенциальные узкие места своего кода там, где позже можно было бы ещё долго медитировать с отладчиком в поисках источника проблемы. Мы рассмотрим разные примеры поведения кода 1С. Разберём результаты выполнения и ответим на вопросы «Почему?», «Как же так?» и «Зачем нам это знать?». 

06.10.2023    23756    SeiOkami    48    

135

Механизмы платформы 1С Системный администратор Платформа 1С v8.3 Бесплатно (free)

Начиная с версии платформы 8.3.22 1С снимает стандартные блокировки БД на уровне страниц. Делаем рабочий скрипт, как раньше.

14.09.2023    18828    human_new    27    

80

WEB-интеграция Универсальные функции Механизмы платформы 1С Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

При работе с интеграциями рано или поздно придется столкнуться с получением JSON файлов. И, конечно же, жизнь заставит проверять файлы перед тем, как записывать данные в БД.

28.08.2023    14729    YA_418728146    7    

166
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Abadonna 3968 25.01.08 18:22 Сейчас в теме
Саш, за 8-ку не скажу, а 7-ке уложился бы в строчек 5-8 ;))))
2. CheBurator 2712 27.01.08 00:47 Сейчас в теме
интересно.. как среагирует на тиа 03/03/03
..???
3. Abadonna 3968 27.01.08 04:28 Сейчас в теме
(2) Еще интереснее: на 99/99/99 ;)
4. Шёпот теней 1782 28.01.08 07:51 Сейчас в теме
Спасибо, конечно и Abadonne и Che_Burashka - но, великим мастерам не пристало смеяться над .... (вставить по по смыслу)...

...

но задача тем не менее остаётся и для меня при все её "простоте" остаётся "не_универсальной" и не решённой...

...

(2) 03/03/03 - если это только одна дата то выбирай как хочешь где, что... если это набор дат, то в сравнении с другими, можно определить...

(3) 99/99/99 - идея хорошая... возникает необходимость в дополнительной проверки возвращаемого значения, ну... но это даже для меня "элементарно"... хи-хи-хи...

Поговорка: программисты разные... кому-то и "разбор" строк - высшая математика...

Поговорка2: программисты разные... одни говорят - другие программируют...
5. Abadonna 3968 28.01.08 07:59 Сейчас в теме
Да ладно тебе! Нашел великих ;))))))))))))
6. Шёпот теней 1782 28.01.08 08:08 Сейчас в теме
лично меня ни сколько не смущает "ваша величие"... и мне и другим есть чему учиться...

другое дело "Интересно мнение всех кому эта проблема интересна… " понимаю, что возможно для вас это и "детский сад" и вам это не интересно... тогда пусть маленькие мальчики ковыряются в песочнице... ...не мешайте большие дяденьки - мы учимся...! и "Я сам..."...
7. soloviev 02.04.12 17:35 Сейчас в теме
ДатаСтрокой = "02.02.2007";
Дата(""+ДатаСтрокой+" 00:00:00");


Так тоже нормально отрабатывает.
Оставьте свое сообщение