gifts2017

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

Опубликовал Александр Шишкин (Шёпот теней) в раздел Программирование - Практика программирования

В моей повседневной деятельности, программиста 1С, часто приходится переводить различные данные из xls и txt в 1С и приводить текстовые строки содержащие «Дату» типа «02.02.2007» или «02\02\2007» или « 02 02 2007» или «2007.02.02» или «02.02.07» и другие варианты … к значению типаДата – ‘2007.02.02’…
Решил написать универсальный код преобразования… Пробовал различные варианты… остановился на том который в обработке… в файле для скачивания… Вкратце: всю строку «загоняю» в массив при этом отсеиваю символы не («0123456789» ИЛИ «символы_разделения_в_дате»)… Далее по символам «символы_разделения_в_дате» делю массив на три значения д-м-г «кладу» в списокЗначений и возвращаю …

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

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

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

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

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

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

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


Скачать файлы

Наименование Файл Версия Размер Кол. Скачив.
ПереводСтрокаВтипДата
.1201263769 5,68Kb
25.09.09
103
.1201263769 5,68Kb 103 Бесплатно
ПереводСтрокаВтипДата_02
.1201613675 5,52Kb
25.09.09
54
.1201613675 5,52Kb 54 Бесплатно

См. также

Подписаться Добавить вознаграждение

Комментарии

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

...

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

...

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

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

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

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

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


Так тоже нормально отрабатывает.
Для написания сообщения необходимо авторизоваться
Прикрепить файл
Дополнительные параметры ответа