|
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 41
|
|
Сравнение Дат В Search Formula06.10.2013, 15:09. Показов 21793. Ответов 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
|
|
| 06.10.2013, 15:09 | |
|
Ответы с готовыми решениями:
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 | ||
Меня интересует, как в 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 | ||
0
|
||
|
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 41
|
||
| 06.10.2013, 18:57 | ||
Кроме нужных доков, у меня в коллекцию попадают документы у которых в поле, по которому критерий отбора, есть цифра 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 | |||
Потому как перечитал кучу постов на форуме, но везде примеры где сравнение идет именно поля типа ДАТА с необходимым диапазоном, а у меня поле в документах ТЕКСТОВОЕ, и не могу его побороть((
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 | ||
0
|
||
|
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 41
|
||
| 07.10.2013, 09:37 | ||
как например вытащить в переменную значение поля, по которому строится запрос? В моем случае - это на основной форме документа поле ДАТА_РАЗРЕШ_ОБРАЩ_ типа ТЕКСТ Как посмотреть значения полей 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 | ||
0
|
||
|
0 / 0 / 0
Регистрация: 06.12.2016
Сообщений: 223
|
||
| 07.10.2013, 09:47 | ||
0
|
||
|
0 / 0 / 0
Регистрация: 01.08.2013
Сообщений: 41
|
||
| 07.10.2013, 09:50 | ||
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 | ||||||
|
ок... результат вот этого выкладывайте:
0
|
||||||
|
0 / 0 / 0
Регистрация: 06.12.2016
Сообщений: 223
|
||
| 07.10.2013, 09:51 | ||
0
|
||
| 07.10.2013, 09:51 | |
|
Помогаю со студенческими работами здесь
20
Сравнение двух дат и вывод дат находящихся между ними Сравнение дат Сравнение дат
Сравнение дат Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
||||
|
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга,
Ты же видел моря и метели.
Как сменялись короны и стяги,
Как эпохи стрелою летели.
- Этот мир — это крылья и горы,
Снег и пламя, любовь и тревоги,
И бескрайние. . .
|
PowerShell Snippets
iNNOKENTIY21 11.11.2025
Модуль PowerShell 5. 1+ : Snippets. psm1
У меня модуль расположен в пользовательской папке модулей, по умолчанию: \Documents\WindowsPowerShell\Modules\Snippets\
А в самом низу файла-профиля. . .
|
PowerShell и онлайн сервисы. Валюта (floatrates.com руб.)
iNNOKENTIY21 11.11.2025
PowerShell функция floatrates-rub
Примеры вызова:
# Указанная валюта 'EUR'
floatrates-rub -Code 'EUR'
# Список имеющихся кодов валют
floatrates-rub -Available
function floatrates-rub {
|
PowerShell и онлайн сервисы. Погода (RP5.ru)
iNNOKENTIY21 11.11.2025
PowerShell функция Get-WeatherRP5rss для получения погоды с сервиса RP5
Примеры вызова
Get-WeatherRP5rss
с указанием id 5484 — Москва (восток, Измайлово) и переносом строки:. . .
|
PowerShell и онлайн сервисы. Погода (wttr)
iNNOKENTIY21 11.11.2025
PowerShell Функция для получения погоды с сервиса wttr
Примеры вызова:
Погода в городе Омск с прогнозом на день, можно изменить прогноз на более дней, для этого надо поменять запрос:. . .
|
|
PowerShell и онлайн сервисы. Валюта (ЦБР)
iNNOKENTIY21 11.11.2025
# Получение курса валют
function cbr (] $Valutes = @('USD', 'EUR', 'CNY')) {
$url = 'https:/ / www. cbr-xml-daily. ru/ daily_json. js'
$data = Invoke-RestMethod -Uri $url
$esc = 27
. . .
|
И решил я переделать этот ноут в машину для распределенных вычислений
Programma_Boinc 09.11.2025
И решил я переделать этот ноут в машину для распределенных вычислений
Всем привет. А вот мой компьютер, переделанный из ноутбука.
Был у меня ноут асус 2011 года. Со временем корпус превратился. . .
|
Мысли в слух
kumehtar 07.11.2025
Заметил среди людей, что по-настоящему верная дружба бывает между теми, с кем нечего делить.
|
Новая зверюга
volvo 07.11.2025
Подарок на Хеллоуин, и теперь у нас кроме Tuxedo Cat есть еще и щенок далматинца:
Хочу еще Симбу взять, очень нравится. . .
|
Инференс ML моделей в Java: TensorFlow, DL4J и DJL
Javaican 05.11.2025
Python захватил мир машинного обучения - это факт. Но когда дело доходит до продакшена, ситуация не так однозначна. Помню проект в крупном банке три года назад: команда data science натренировала. . .
|