Как найти уникальные поля в коллекции ?

  • Автор темы Sandro
  • Дата начала
S

Sandro

#1
Есть коллекция документов(LS), в документе есть поле, как получить массив с перечнем уникальных значений полей ?
В голову приходит только сравнивание подокументно, как нить "поизящнее" <_< это можно сделать ?
 
A

amigolinx

#4
По коллекции все равно пробежать придется, чтобы взять значения из доков. Попутно тулим их в массив, а на выходе на этом массиве выполняем ArrayUnique, которая как раз и есть ЛС-функцией <_<
 
E
#6
А чего их искать? Все поля уникальные, на то они и поля.
 
D

Darker

#7
dim uniqueList list as string
dim doc as notesdocument

'col - твоя коллекция
for i=1 to col.count 'твоя коллекция
set doc=col.getnthdocument(i)
v=doc.getitemvalue("Твое_поле")(0)
if not iselement(uniqueList(v)) then uniqueList(v)=v
next


' в конце получишь уникальный массив-список uniqueList
 

hosm

* so what *
18.05.2009
2 442
6
#8
Sandro
в коллекции могут быть только документы, нет у лотуса стандартной коллекции полей))).
Меня вообще вот правильно учили различать поля на форме (fields) и поля в документе (items).
Поля в документе могут быть получены либо из документов в NotesDocumentCollection, как у Вас, либо из энтри вьюшки, если они могут отображаться в представлении и могут быть взяты через ColumnValues(или взяты из документов, которые попали в представление).

getnthdocument(i) лучше не юзать. неэффективно. поищите, обсуждалось. Брать GetFirstDocument...GetNextDocument и аналогичное
 

ToxaRat

Чёрный маг
Lotus team
06.11.2007
3 231
17
#9
Код:
call col.stampall("Field", "0")
и всё, теперь можно спать спокойно, больше уников нету ;)
 

Omh

Lotus team
04.07.2007
2 210
1
#10
А бы тоже пробежка по докам + list as string делал бы
 

Xalet

Well-known member
08.08.2008
410
0
#11
А я бы изначально коллекцию "уникальной" постарался бы получить.
 

Medevic

Что это ? :)
Lotus team
10.12.2004
3 346
1
#14
Тогда и отсортировать нужно.
Лучше уж пройтись по всем значениям и сравнить.
 
S

Sandro

#16
Понял, спасиб :) Просто предполагается ,что документов будет большое количество, а код нужен что бы сформировать достаточно сложный по структуре отчёт в excell, если будет долго обрабатываться это не есть хорошо. Как показывает практика, чуть формирование задержится, сразу лезут, завершать задачу и писать , что всё зависает ))))
 
D

Darker

#17
С учетом многозначности и разных типов(приводим все в String)


Код:
dim doc as notesdocument
'col - твоя коллекция
set doc=col.getfirstdocument
while not doc is nothing 'твоя коллекция
if doc.hasitem("Твое_поле") then
temp=doc.getitemvalue("Твое_поле")
if isarray(temp) then v=cstr(join(temp,"^"))+"^" else v=v+cstr(temp)+"^"
end if
set doc=col.getnextdocument(doc)
wend
uniqueArr=arrayunique(fulltrim(split(v,"^")))

ну или создать временную папку(сгруппированную по твоему полю), закинуть коллекцию в папку, и пройтись нафигатором по первому столбцу
 
S

Sandro

#18
И снован ниид хелп )))) Извиняюсь если туплю, но вот пытаюсь сделать выборку респонсов для нужного мне дока

Set dscoll=db.Search(|$Ref="|+note.UniversalID+|"|,Nothing,0)

Не получается ((((