Bahasa Q - Pengindeksan

Daftar diurutkan dari kiri ke kanan berdasarkan posisi itemnya. Offset item dari awal daftar disebut itsindex. Jadi, item pertama memiliki indeks 0, item kedua (jika ada) memiliki indeks 1, dll. Daftar hitungann memiliki domain indeks dari 0 untuk n–1.

Notasi Indeks

Diberikan daftar L, item di indeks i diakses oleh L[i]. Mengambil item dengan indeksnya disebutitem indexing. Sebagai contoh,

q)L:(99;98.7e;`b;`abc;"z")

q)L[0]
99

q)L[1]
98.7e

q)L[4]
"z

Tugas yang Diindeks

Item dalam daftar juga dapat ditetapkan melalui pengindeksan item. Jadi,

q)L1:9 8 7

q)L1[2]:66      / Indexed assignment into a simple list
                / enforces strict type matching.
                
q)L1
9 8 66

Daftar dari Variabel

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)

Daftar Bergabung

Operasi paling umum pada dua daftar adalah menggabungkan keduanya untuk membentuk daftar yang lebih besar. Lebih tepatnya, operator gabungan (,) menambahkan operan kanannya ke akhir operan kiri dan mengembalikan hasilnya. Ia menerima atom di salah satu argumen.

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

Bersarang

Kompleksitas data dibangun dengan menggunakan daftar sebagai item dari daftar.

Kedalaman

Jumlah level bersarang untuk daftar disebut kedalamannya. Atom memiliki kedalaman 0 dan daftar sederhana memiliki kedalaman 1.

q)l1:(9;8;(99;88))

q)count l1
3

Berikut adalah daftar kedalaman 3 yang memiliki dua item -

q)l5
9
(90;180;900 1800 2700 3600)

q)count l5
2

q)count l5[1]
3

Mengindeks di Kedalaman

Dimungkinkan untuk mengindeks langsung ke item dari daftar bertingkat.

Repeated Item Indexing

Mengambil item melalui indeks tunggal selalu mengambil item paling atas dari daftar bertingkat.

q)L:(1;(100;200;(300;400;500;600)))

q)L[0]
1

q)L[1]
100
200
300 400 500 600

Sejak hasilnya L[1] itu sendiri adalah daftar, kita dapat mengambil elemennya menggunakan indeks tunggal.

q)L[1][2]
300 400 500 600

Kita dapat mengulangi pengindeksan tunggal sekali lagi untuk mengambil item dari daftar bersarang paling dalam.

q)L[1][2][0]
300

Anda dapat membaca ini sebagai,

Dapatkan item pada indeks 1 dari L, dan darinya mengambil item pada indeks 2, dan darinya mengambil item pada indeks 0.

Notation for Indexing at Depth

Ada notasi alternatif untuk pengindeksan berulang ke konstituen daftar bertingkat. Pengambilan terakhir juga bisa ditulis sebagai,

q)L[1;2;0]
300

Penugasan melalui indeks juga bekerja secara mendalam.

q)L[1;2;1]:900

q)L
1
(100;200;300 900 500 600)

Indeks Terpilih

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,

Ambil semua item di posisi kedua dari setiap daftar di tingkat teratas.

Interpret L[;;2] as,

Ambil item di posisi ketiga untuk setiap daftar di tingkat kedua.