Форум программистов, компьютерный форум, киберфорум
HCL Notes: Программирование
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.52/112: Рейтинг темы: голосов - 112, средняя оценка - 4.52
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 41

Сравнение Дат В Search Formula

06.10.2013, 15:09. Показов 21842. Ответов 29
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток уважаемые. Проблемка нарисовалась ...
Существует агент, который отбирает документы и обрабатывает их неким образом. Проблема в том, что в отбор попадают ненужные документы. Привожу код:

...
Dim nw As New NotesUIWorkspace
Dim nses As New NotesSession
Dim db As NotesDatabase
Dim OtchetDoc As NotesDocument
Dim doc As NotesDocument
Dim doccol As NotesDocumentCollection
Dim begindata As NotesDateTime, enddata As NotesDateTime


Set OtchetDoc=nw.CurrentDocument.Document
Set db = nses.CurrentDatabase

Set begindata=New NotesDateTime(OtchetDoc.begin(0))
Set enddata=New NotesDateTime(OtchetDoc.end(0))

searchFormula$ = { Form = "Vhod" & @Left(ТИП_ДОКУМЕНТА;6)="Жалобы" & ДАТА_РАЗРЕШ_ОБРАЩ_<> "" & @ToTime(ДАТА_РАЗРЕШ_ОБРАЩ_) => [}+ begindata.Dateonly +{] & @ToTime(ДАТА_РАЗРЕШ_ОБРАЩ_) =< [}+ enddata.Dateonly +{] }

Set doccol = db.Search( searchFormula$, Nothyng, 0)
...

Немного пояснений:
- на форме Отчета поля begin и end типа ДАТА/ВРЕМЯ
- на основной форме документа поле ДАТА_РАЗРЕШ_ОБРАЩ_ типа ТЕКСТ

Интересует:
- почему в коллекцию попадают документы, у которых ДАТА_РАЗРЕШ_ОБРАЩ_ выходит за рамки, установленные интервалом ?
- как правильно работать (сравнивать между собой) с текстовыми полями и полями дата/время в рамках написания формул отбора ?

Заранее благодарю!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.10.2013, 15:09
Ответы с готовыми решениями:

Сравнение Дат
есть одна дата в дебагере она X = &quot;22.02.2013&quot; и вторая Y= &quot;19.09.2013&quot; если If x&lt;y Then то всегда будет больше та дата, у которой...

сравнение дат
есть документы созданные по форме tplan а на форме поле dataplan тип дата понадобился сранить дату сохраненный в этой форме с другой...

Сравнение дат
Подскажите, пожалуйста, как сравнивать даты в LS. У меня не работает следующий код: ...

29
1 / 1 / 0
Регистрация: 07.12.2009
Сообщений: 1,197
06.10.2013, 15:14
Поищите по форуму пожалуйста. Здесь не то, чтобы много, а очень много было подобных тем.
0
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 41
06.10.2013, 16:02
Цитата Сообщение от VladSh
Поищите по форуму пожалуйста. Здесь не то, чтобы много, а очень много было подобных тем.
В том-то и дело, что я бы не писал сюда, если бы нашел на форуме здесь что-либо похожее. Есть темы, но они мне не подходят.
Меня интересует, как в searchformula правильно преобразовать текстовое поле в дату и далее сравнить его с другим полем даты или с переменной типа дата. Пробовал различные конструкции, остановился на приведеннйо выше,

@ToTime(ДАТА_РАЗРЕШ_ОБРАЩ_) => [}+ begindata.Dateonly +{] & @ToTime(ДАТА_РАЗРЕШ_ОБРАЩ_) =< [}+ enddata.Dateonly +{]

но она не работает корректно, почему-то проскальзывают (не все, но некоторые и непонятно почему) документы, которые не удовлетворяют этому условию.
0
0 / 0 / 0
Регистрация: 27.10.2011
Сообщений: 2,124
06.10.2013, 16:41
но она не работает корректно, почему-то проскальзывают (не все, но некоторые и непонятно почему) документы, которые не удовлетворяют этому условию.
Смотрите какие проскальзывают, что хранится в полях, что хранится в критериях, только ли там дата, а может еще и время есть.
Чудес все же не бывает...
0
0 / 0 / 0
Регистрация: 14.01.2009
Сообщений: 257
06.10.2013, 16:48
{ Form = "Vhod" & @Left(ТИП_ДОКУМЕНТА;6)="Жалобы" & ДАТА_РАЗРЕШ_ОБРАЩ_<> "" & ДАТА_РАЗРЕШ_ОБРАЩ_ => [}+ cstr(doc.begindata(0)) +{] & ДАТА_РАЗРЕШ_ОБРАЩ_ =< [}+ cstr(doc.enddata(0)) +{] }
0
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 41
06.10.2013, 18:03
Цитата Сообщение от erdi
{ Form = "Vhod" & @Left(ТИП_ДОКУМЕНТА;6)="Жалобы" & ДАТА_РАЗРЕШ_ОБРАЩ_<> "" & ДАТА_РАЗРЕШ_ОБРАЩ_ => [}+ cstr(doc.begindata(0)) +{] & ДАТА_РАЗРЕШ_ОБРАЩ_ =< [}+ cstr(doc.enddata(0)) +{] }
такая конструкция не работает .. не находит вообще ничего .. наверно из-за того что надо еще правильно конвертнуть поле ДАТА_РАЗРЕШ_ОБРАЩ_ в дату .. так как оно текстовое
0
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 41
06.10.2013, 18:57
Цитата Сообщение от savl
Смотрите какие проскальзывают, что хранится в полях, что хранится в критериях, только ли там дата, а может еще и время есть.
Чудес все же не бывает...
К примеру интервал у меня с 01.07.2013 по 31.07.2013
Кроме нужных доков, у меня в коллекцию попадают документы у которых в поле, по которому критерий отбора, есть цифра 07 например. То есть в коллекции у меня документы с датой (поле текстовое) 07.08.2013. Хотя их тут быть не должно ))
0
0 / 0 / 0
Регистрация: 27.10.2011
Сообщений: 2,124
06.10.2013, 19:17
Ответ на вопрос, в первом же посте:
Посмотри на пример запроса, который указал автор.
У него поле изначально date - time, а даты текстом.
У тебя же ситуация наоборот, границы ты преобразовал, а поле кто будет?
Сравнивать надо в едином формате, преобразуй все в формат даты.
0
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 41
06.10.2013, 19:44
Цитата Сообщение от savl
У тебя же ситуация наоборот, границы ты преобразовал, а поле кто будет?
Сравнивать надо в едином формате, преобразуй все в формат даты.
Мой главный вопрос: Как правильно на собаках в контексте searchformula преобразовать текстовое поле (из документов для отбора) в тип ДАТА/ВРЕМЯ ?
Потому как перечитал кучу постов на форуме, но везде примеры где сравнение идет именно поля типа ДАТА с необходимым диапазоном, а у меня поле в документах ТЕКСТОВОЕ, и не могу его побороть((



Цитата Сообщение от savl
Ответ на вопрос, в первом же посте:
Посмотри на пример запроса, который указал автор.
У него поле изначально date - time, а даты текстом.
Дело в том, что я пытался уже делать так как писали в приведенном Вами посте. результат такой же. Вот мой код:
searchFormula$ = { Form = "VhodStandart" & @Left(ТИП_ДОКУМЕНТА;6)="Жалобы" & ДАТА_РАЗРЕШ_ОБРАЩ_<> "" & @ToTime(@text(ДАТА_РАЗРЕШ_ОБРАЩ_)) => [}+ begindata.Dateonly +{] & @ToTime(@text(ДАТА_РАЗРЕШ_ОБРАЩ_)) =< [}+ enddata.Dateonly +{] }
Или же все равно что-то не так?
Очень прошу помочь с этой темой разобраться,.. я подозреваю что тут какая-то мелочь, а вот не могу понять какая ...

Кстати, не пойму почему теперь не попадают в коллекцию документы, явно входящие в интервал. Ну и осталась проблема с тем, что в коллекцию попадают документы где есть цифра из интервала .. по примеру моего предыдущего поста
0
0 / 0 / 0
Регистрация: 06.12.2016
Сообщений: 223
07.10.2013, 09:21
Я при непонятках с отбором вывожу на статусбар переменную, в которой хранится запрос. Как правило все становится ясно :D
0
0 / 0 / 0
Регистрация: 14.01.2009
Сообщений: 257
07.10.2013, 09:25
явно что-то вы еще недоговариваете или же какие-то еще условия у вас стоят, про которые вы не знаете.
ту конструкцию что я привел - всегда у меня все правильно отбирало(специально даже протестировал с тестовой формой где даты в виде текста)
для вас наверное самый простой способ будет открыть дизайнер-создать представление и в формулу отбора документов подставлять различные формулы и смотреть какие документы они возвращают. Как-только найдете формулу для представления - копируйте ее в код и заменяйте своими данными. Результат должен будет совпасть
0
0 / 0 / 0
Регистрация: 27.10.2011
Сообщений: 2,124
07.10.2013, 09:27
@ToTime @TextToTime( string )
0
0 / 0 / 0
Регистрация: 06.12.2016
Сообщений: 223
07.10.2013, 09:30
Цитата Сообщение от juk-777
К примеру интервал у меня с 01.07.2013 по 31.07.2013
Кроме нужных доков, у меня в коллекцию попадают документы у которых в поле, по которому критерий отбора, есть цифра 07 например. То есть в коллекции у меня документы с датой (поле текстовое) 07.08.2013. Хотя их тут быть не должно ))
Все нормально отбирается... "01.07.2013" < "07.08.2013" & "07.08.2013" < "31.07.2013" - есть истина, ибо "01"<"07"<"31".
0
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 41
07.10.2013, 09:37
Цитата Сообщение от Anatoly
Я при непонятках с отбором вывожу на статусбар переменную, в которой хранится запрос. Как правило все становится ясно
Может быть глупый вопрос сейчас задам: но как это сделать?
как например вытащить в переменную значение поля, по которому строится запрос? В моем случае - это на основной форме документа поле ДАТА_РАЗРЕШ_ОБРАЩ_ типа ТЕКСТ

Как посмотреть значения полей begin и end типа ДАТА/ВРЕМЯ на открытой форме, то есть в uidoc - это понятно, а вот куда присвоить и как значения поля из тех документов, которые надо отобрать? Вся загвоздка как я понимаю в конвертации текстового поля в дата, в моем запросе, потому как эта конструкция [}+ enddata.Dateonly +{] } у меня правильно написана (уже кучу примеров нашел на форуме с такими конструкциями). НО, как я уже говорил, нет на форуме примера, где с этим [}+ enddata.Dateonly +{] } надо сравнить текстовое поле из документов.

Буду благодарен за любые советы.
0
0 / 0 / 0
Регистрация: 27.10.2011
Сообщений: 2,124
07.10.2013, 09:43
довели...

searchFormula$ = { Form = "VhodStandart" & @Left(ТИП_ДОКУМЕНТА;6)="Жалобы" & ДАТА_РАЗРЕШ_ОБРАЩ_<> "" & @TextToTime(@text(ДАТА_РАЗРЕШ_ОБРАЩ_)) => [}+ begindata.Dateonly +{] & @TextToTime(@text(ДАТА_РАЗРЕШ_ОБРАЩ_)) =< [}+ enddata.Dateonly +{] }

Сделать представление (View) с данной формулой отбора, посмотреть результаты.
Если все верно юзать в поиске, если нет. Править формулу.
0
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 41
07.10.2013, 09:46
Цитата Сообщение от erdi
явно что-то вы еще недоговариваете или же какие-то еще условия у вас стоят, про которые вы не знаете.
как я могу не знать про условия, которые у меня есть, если я собственноручно пишу код запроса) И договариваю я все- так как не люблю вводить людей в заблуждение .. вырвал кусок из кода и запостил сюда .. в пером своем вопросе. Существует только одна searchformula по которой я хочу сделать db.Search. Но почему-то наткнулся на непонятки)
0
0 / 0 / 0
Регистрация: 06.12.2016
Сообщений: 223
07.10.2013, 09:47
Цитата Сообщение от savl
довели...

searchFormula$ = { Form = "VhodStandart" & @Left(ТИП_ДОКУМЕНТА;6)="Жалобы" & ДАТА_РАЗРЕШ_ОБРАЩ_<> "" & @TextToTime(@text(ДАТА_РАЗРЕШ_ОБРАЩ_)) => [}+ begindata.Dateonly +{] & @TextToTime(@text(ДАТА_РАЗРЕШ_ОБРАЩ_)) =< [}+ enddata.Dateonly +{] }

Сделать представление (View) с данной формулой отбора, посмотреть результаты.
Если все верно юзать в поиске, если нет. Править формулу.
Сдается мне, ДАТА_РАЗРЕШ_ОБРАЩ_<> "" можно смело опустить.
0
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 41
07.10.2013, 09:50
Цитата Сообщение от savl
довели...

searchFormula$ = { Form = "VhodStandart" & @Left(ТИП_ДОКУМЕНТА;6)="Жалобы" & ДАТА_РАЗРЕШ_ОБРАЩ_<> "" & @TextToTime(@text(ДАТА_РАЗРЕШ_ОБРАЩ_)) => [}+ begindata.Dateonly +{] & @TextToTime(@text(ДАТА_РАЗРЕШ_ОБРАЩ_)) =< [}+ enddata.Dateonly +{] }

Сделать представление (View) с данной формулой отбора, посмотреть результаты.
Если все верно юзать в поиске, если нет. Править формулу.
:sorry: Вы меня конечно простите, но и подобную конструкцию я делал - результат - тот же что и при
searchFormula$ = { Form = "VhodStandart" & @Left(ТИП_ДОКУМЕНТА;6)="Жалобы" & ДАТА_РАЗРЕШ_ОБРАЩ_<> "" & @ToTime(ДАТА_РАЗРЕШ_ОБРАЩ_) => [}+ begindata.Dateonly +{] & @ToTime(ДАТА_РАЗРЕШ_ОБРАЩ_) =< [}+ enddata.Dateonly +{] }

Документы отбираются теже самые - прям один в один совпадают.
0
0 / 0 / 0
Регистрация: 27.10.2011
Сообщений: 2,124
07.10.2013, 09:51
ок... результат вот этого выкладывайте:

LotusScript
1
msgbox searchFormula$
вставить после формулы, но до search
0
0 / 0 / 0
Регистрация: 06.12.2016
Сообщений: 223
07.10.2013, 09:51
Цитата Сообщение от juk-777
Может быть глупый вопрос сейчас задам: но как это сделать?
как например вытащить в переменную значение поля, по которому строится запрос? В моем случае - это на основной форме документа поле ДАТА_РАЗРЕШ_ОБРАЩ_ типа ТЕКСТ
Есть дебаггер, есть Print
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.10.2013, 09:51
Помогаю со студенческими работами здесь

Сравнение двух дат и вывод дат находящихся между ними
Здравствуйте! Тут такое дело, вводятся две определенные ДАТЫ в Edit1 и Edit2 в формате ДД.ММ.ГГГГ, нужно найти все ДАТЫ, которые...

Сравнение дат
Подскажите как можно сравнить две даты с помощью jQueri в таком формате 04/06/2016

Сравнение дат
Добрый, день. Подскажите пожалуйста как можно решить поставленную задачу. Для каждой записи CAMA нужно проверить ближайшие ряды с...

Сравнение дат
Добрый день! Нужна ваша помощь. Задача в следующем: есть дата в формате 30 дек 2015, нужно узнать это раньше или позже, допустим, 20 окт...

Сравнение дат
1. Известны даты рождения двух человек. Определить, кто из них старше. Для решения задачи написать именованную функцию CLISP


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
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