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.