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,

두 번째 수준의 각 목록에 대해 세 번째 위치에있는 항목을 검색합니다.