Q 언어-인덱싱
목록은 항목의 위치에 따라 왼쪽에서 오른쪽으로 정렬됩니다. 목록의 시작 부분에서 항목의 오프셋을index. 따라서 첫 번째 항목은 인덱스 0, 두 번째 항목 (있는 경우)에는 인덱스 1 등이 있습니다. 개수 목록n 색인 도메인이 있음 0 ...에 n–1.
색인 표기
주어진 목록 L, 인덱스 항목 i 에 의해 액세스됩니다 L[i]. 인덱스로 항목 검색이 호출됩니다.item indexing. 예를 들면
q)L:(99;98.7e;`b;`abc;"z")
q)L[0]
99
q)L[1]
98.7e
q)L[4]
"z
색인화 된 할당
목록의 항목은 항목 인덱싱을 통해 할당 할 수도 있습니다. 그러므로,
q)L1:9 8 7
q)L1[2]:66 / Indexed assignment into a simple list
/ enforces strict type matching.
q)L1
9 8 66
변수의 목록
q)l1:(9;8;40;200)
q)l2:(1 4 3; `abc`xyz)
q)l:(l1;l2) / combining the two list l1 and l2
q)l
9 8 40 200
(1 4 3;`abc`xyz)
목록에 합류
두 목록에서 가장 일반적인 작업은 두 목록을 결합하여 더 큰 목록을 만드는 것입니다. 보다 정확하게는 조인 연산자 (,)는 오른쪽 피연산자를 왼쪽 피연산자의 끝에 추가하고 결과를 반환합니다. 두 인수 중 하나에서 원자를받습니다.
q)1,2 3 4
1 2 3 4
q)1 2 3, 4.4 5.6 / If the arguments are not of uniform type,
/ the result is a general list.
1
2
3
4.4
5.6
중첩
데이터 복잡성은 목록을 목록 항목으로 사용하여 구축됩니다.
깊이
목록의 중첩 수준 수를 깊이라고합니다. 원자의 깊이는 0이고 단순 목록의 깊이는 1입니다.
q)l1:(9;8;(99;88))
q)count l1
3
다음은 두 항목이있는 깊이 3의 목록입니다.
q)l5
9
(90;180;900 1800 2700 3600)
q)count l5
2
q)count l5[1]
3
심층 인덱싱
중첩 된 목록의 항목으로 직접 인덱싱 할 수 있습니다.
Repeated Item Indexing
단일 인덱스를 통해 항목을 검색하면 항상 중첩 된 목록에서 최상위 항목이 검색됩니다.
q)L:(1;(100;200;(300;400;500;600)))
q)L[0]
1
q)L[1]
100
200
300 400 500 600
결과 이후 L[1] 그 자체가 목록이므로 단일 색인을 사용하여 요소를 검색 할 수 있습니다.
q)L[1][2]
300 400 500 600
단일 인덱싱을 한 번 더 반복하여 가장 안쪽에있는 중첩 목록에서 항목을 검색 할 수 있습니다.
q)L[1][2][0]
300
이것을 다음과 같이 읽을 수 있습니다.
L에서 인덱스 1에있는 항목을 가져 와서 인덱스 2에있는 항목을 검색하고 여기에서 인덱스 0에있는 항목을 검색합니다.
Notation for Indexing at Depth
중첩 된 목록의 구성 요소에 대한 반복 인덱싱에 대한 대체 표기법이 있습니다. 마지막 검색은 다음과 같이 작성할 수도 있습니다.
q)L[1;2;0]
300
색인을 통한 할당도 심층적으로 작동합니다.
q)L[1;2;1]:900
q)L
1
(100;200;300 900 500 600)
제거 된 지수
Eliding Indices for a General List
q)L:((1 2 3; 4 5 6 7); (`a`b`c;`d`e`f`g;`0`1`2);("good";"morning"))
q)L
(1 2 3;4 5 6 7)
(`a`b`c;`d`e`f`g;`0`1`2)
("good";"morning")
q)L[;1;]
4 5 6 7
`d`e`f`g
"morning"
q)L[;;2]
3 6
`c`f`2
"or"
Interpret L[;1;] as,
최상위 수준에서 각 목록의 두 번째 위치에있는 모든 항목을 검색합니다.
Interpret L[;;2] as,
두 번째 수준의 각 목록에 대해 세 번째 위치에있는 항목을 검색합니다.