Bantuan:Ungkapan bersyarat
Bagian dari seri tentang |
Halaman Bantuan Wikipedia Bahasa Indonesia |
---|
- Lihat versi terbaru di (Inggris) mw:Help:ParserFunctions
ParserFunctions (fungsi-fungsi parser) adalah sekumpulan fungsi-fungsi logika dan kalkulasi dalam MediaWiki: mw:Extension:ParserFunctions. Sejak pertengahan April 2006 piranti lunak MediaWiki dengan menggunakan Sintaks-Wiki memperbolehkan digunakannya beberapa konstruksi suatu bahasa pemrograman untuk diterapkan dalam templat.
Konstruksi-konstruksi bahasa program ini seharusnya hanya digunakan secara eksklusif dalam ruang nama templat dan dipertimbangkan saat digunakan. Tidak setiap kemungkinan pemanfaatannya benar-benar berarti atau bermanfaat. Sintaks-sintaks bahasa pemrograman ini masih dapat berubah. Konstruksi pemrograman yang tidak cukup terdokumentasi, akan kembali dihapuskan.
Berbeda dengan fungsi parser biasa yang bisa tidak menggunakan tanda pagar "#", penggunaan ParserFunctions harus memakai tanda pagar di awal fungsi. ParserFunctions memiliki sintaks seperti berikut:
{{#namafungsi: argumen1 | argumen2 | argumen3..}}
Mohon perhatikan bahwa ekstensi ini harus dipasang secara manual, dan tidak langsung terpasang ketika sebuah MediaWiki baru dipasang. Lihat Istimewa:Versi untuk mengetahui apakan ekstensi ini sudah dipasang atau belum.
Fungsi-fungsi
Sekarang ini, modul ini memiliki sepuluh fungsi yaitu:
expr
,
if
,
ifeq
,
ifexist
,
ifexpr
,
iferror
,
switch
,
time
,
rel2abs
, dan
titleparts
.
#expr:
sintaks:
- {{ #expr:
ekspresi
}}
- {{ #expr:
Fungsi expr
digunakan untuk menghitung perhitungan (ekspresi) matematika didasarkan atas permutasi dari angka-angka (atau variabel/parameter yang diterjemahkan dalam angka-angka) dan operator. Fungsi ini tidak berlaku untuk string. (gunakan ifeq untuk string). Keakuratan dan format angka berbeda-beda tergantung dari sistem operasi peladen.
Dalam perhitungan kompleks, operator dihitung dari kiri ke kanan dengan preseden tertentu:
- pengelompokan (tanda kurung);
- unary (tanda +/- dan NOT);
- perkalian(*, /, div, mod);
- penjumlahan (+, -);
- pembulatan;
- perbandingan (=, !=, <, >, dll.);
- logical AND;
- logical OR.
Jika menghitung sebagai boolean, "0" dianggap FALSE (salah) dan karakter lain selain spasi "TRUE" (benar) (TRUE di boolean dilambangkan sebagai "1").
Macam operator:
Operator | Operasi | Contoh | Hasil |
---|---|---|---|
tidak ada | {{ #expr: 123456789012345 }}
|
1.2345678901234E+14 | |
{{ #expr: 0.000001 }}
|
1.0E-6 | ||
Aritmatika | |||
+ | Unary tanda positif | {{ #expr: +30 * +7 }}
|
210 |
- | Unary tanda negatif | {{ #expr: -30 * -7 }}
|
210 |
* | Perkalian | {{ #expr: 30 * 7 }}
|
210 |
/ div |
Pembagian | {{ #expr: 30 / 7 }}
|
4.2857142857143 4.2857142857143 |
+
|
Penjumlahan | {{ #expr: 30 + 7 }}
|
37 |
-
|
Pengurangan | {{ #expr: 30 - 7 }}
|
23 |
Logika | |||
not | Unary NOT logical NOT |
{{ #expr: not 0 * 7 }}
|
7 7 |
and | Logical AND |
{{ #expr: |
0 |
or | Logical OR |
{{ #expr: |
1 |
Perbandingan | |||
= | Persamaan (numerical & logical) | {{ #expr: 30 = 7 }}
|
0 |
<> != |
Pertidaksamaan, logical exclusive or | {{ #expr: 30 <> 7 }}
|
1 1 |
< | Kurang dari |
{{ #expr: |
0 |
> | Lebih dari |
{{ #expr: |
1 |
<= | Kurang dari sama dengan |
{{ #expr: |
0 |
>= | Lebih dari sama dengan |
{{ #expr: |
1 |
Lain-lain | |||
( ) | Operator pengelompokan | {{ #expr: (30 + 7) * 7 }}
|
259 |
mod | "Modulo" sisa pembagian. Catatan: div dan mod berbeda dari semua bahasa pemrograman. |
{{ #expr: 30 mod 7 }}
|
2 -2 0 |
round | Membulatkan. | {{ #expr: 30 / 7 round 4 }}
|
4.2857 4.3 1900 -3 |
trunc | Menghilangkan desimal. | {{ #expr: trunc1.2 }}
|
1 -1 |
floor | Membulatkan ke intejer terdekat yang sama dengan atau lebih kecil dari angka tersebut. | {{ #expr: floor1.2 }}
|
1 -2 |
ceil | Membulatkan ke intejer terdekat yang sama dengan atau lebih besar dari angka tersebut. | {{ #expr: ceil1.2 }}
|
2 -1 |
#if:
sintaks:
- {{ #if:
<string kondisi> | <kode jika benar>
}}
- {{ #if:
atau bisa juga dilihat dalam pola if-then-else sebagai berikut:
- {{ #if:
<string kondisi> | <kode jika benar> | <kode jika salah>
}}
- {{ #if:
Fungsi if
bekerja seperti if-then-else (jika-maka-jika_tidak). Kondisi yang diberikan akan selalu benar kecuali dikosongkan atau hanya berisi spasi. Kode di argumen kedua akan dijalankan jika nilai fungsinya benar, dan argumen ketiga akan dijalankan jika nilai fungsinya salah (salah satu atau keduanya dapat kosong, dan kode-jika-salah dapat tidak ditulis sama sekali).
Perbandingan yang dilakukan adalah untuk teks, bukan ekspresi matematika, jadi perbandingan matematika akan selalu dianggap benar; Contoh: {{#if: 1 = 2|benar|salah}}
akan menghasilkan "benar", karena string "1 = 2" tidak merupakan string kosong. Untuk membandingkan string gunakan ifeq. Sedangkan untuk membandingkan angka, gunakan ifexpr.
<---
It is not possible to distinguish between an undefined parameter in a template and a blank one (it is possible with #ifexpr
).
-->
Fungsi if
digunakan untuk menggantikan pemakaian "hiddenstructure"
dan templat {{qif}}. Templat {{qif}} memiliki tingkat kompleksitas tinggi yang menyebabkan waktu yang lama untuk menghasilkan halaman wiki yang memakai templat tersebut.
Contoh:
- {{ #if:
foo | lakukan jika benar | lakukan jika salah
}}
= lakukan jika benar
- {{ #if:
0 | lakukan jika benar | lakukan jika salah
}}
= lakukan jika benar
- {{ #if:
| lakukan jika benar | lakukan jika salah
}}
= lakukan jika salah
Dalam templat, function if dapat digunakan dalam sintaks berikut:
{{Templat|parameter=sesuatu}} {{Templat}} {{Templat|parameter=}} | | | | | | | | | {{#if: {{{parameter|}}} | parameter didefinisikan | parameter tidak didefinisikan atau kosong }}
#ifeq:
sintaks:
- {{ #ifeq:
<teks 1> | <teks 2> | <kode jika setara>
}}
- {{ #ifeq:
- {{ #ifeq:
<teks 1> | <teks 2> | <kode jika setara> | <kode jika tak setara>
}}
- {{ #ifeq:
Fungsi ifeq
membandingkan dua string atau angka, dan akan menghasilkan argumen ketiga jika nilai fungsinya benar, atau akan menghasilkan argumen keempat jika nilai fungsinya salah (salah satu atau keduanya dapat kosong, dan kode-jika-tak-setara dapat tidak ditulis sama sekali).
Perbandingan string ini sensitif terhadap huruf besar/huruf kecil (contoh, A != a). Jika kedua string dapat dijadikan angka, mereka akan dibandingkan secara numerikal (contoh, 01 = 1); Untuk memaksa perbadingan string, tambahkan karakter non-angka (seperti tanda kutip "
) pada kedua argumen.
Isu: (belum diterjemahkan)
Contoh:
- {{ #ifeq:
teks 1 | teks 2 | kode setara | kode tak setara
}}
= kode tak setara
- {{ #ifeq:
teks 1 | teks 1 | kode setara | kode tak setara
}}
= kode setara
#ifexist:
sintaks:
- {{ #ifexist:
<nama halaman> | <kode jika ada> | <kode jika tidak ada>
}}
- {{ #ifexist:
Fungsi ifexist
menghasilkan salah satu dari dua kemungkinan, tergantung dari apakah nama halaman yang dimasukkan ada atau tidak.
Contoh:
#ifexpr:
sintaks:
- {{ #ifexpr:
<ekspresi> | <maka> | <jika tidak>
}}
- {{ #ifexpr:
Fungsi ifexpr
menghitung suatu operasi (ekspresi) matematika (lihat expr) dan menghasilkan salah satu dari dua kemungkinan, tergantung dari perhitungan tersebut benar atau salah.
Contoh:
- {{ #ifexpr:
10 > 9 | ya | tidak
}}
ya -- Karena 10 lebih besar dari 9
#switch:
sintaks:
{{#switch: <nilai yang dibandingkan> | <nilai>1 = <hasil>1 | <nilai>2 = <hasil>2 | ... | <nilai>n = <hasil>n | <hasil> default }}
Fungsi switch
membandingkan antara suatu nilai dengan banyak nilai lainnya, dan menghasilkan string (yang berada setelah tanda samadengan) jika ada yang cocok. Jika tidak ada yang cocok, maka nilai terakhir yang tidak memiliki (jika ada) tanda samadengan-lah yang akan dihasilkan. Anda dapat memberikan hasil default dengan #default
:
{{#switch: <nilai yang dibandingkan> | <nilai> = <hasil> | #default = <hasil default> }}
"switch" dapat digunakan untuk semua penggunaan #ifeq (tapi tidak sebaliknya):
- {{ #switch:
a | a=benar| salah
}}
menghasilkan benar
- {{ #ifeq:
a | a | benar| salah
}}
menghasilkan benar
#time:
sintaks:
- {{ #time:
format
}}
- {{ #time:
- {{ #time:
format| waktu
}}
- {{ #time:
Fungsi time
adalah untuk pemformatan waktu dan tanggal (hanya untuk waktu sejak 1 Jan 1970!). Jika "waktu" tidak diberikan, fungsi ini akan memakai waktu saat artikel yang bersangkutan dikonversi ke HTML. Dikarenakan adanya cache, halaman yang memakai fungsi ini perlu untuk diperbaharui dengan purge atau null edit.
Format kode/parameter:
Kode | Deskripsi | Contoh keluaran | Hasil |
---|---|---|---|
Tahun: | |||
Y | 4-digit tahun. | e.g. 2006 | 2024 |
y | 2-digit tahun. | 00 hingga 99, e.g. 06 untuk tahun 2006. | 24 |
Bulan: | |||
n | Bulan ke- (tanpa awalan 0). | 1 hingga 12 | 10 |
m | Bulan ke- (dengan awalan 0). | 01 hingga 12 | 10 |
M | Tiga huruf nama bulan. | Jan hingga Des | Okt |
F | Nama bulan lengkap | Januari hingga Desember | Oktober |
Minggu: | |||
W | ISO 8601 angka minggu (satu minggu dalam tahun ISO adalah dari senin hingga minggu, dan minggu ke-1 selalu memiliki tanggal 4 Januari atau hari kamis pertama pada kalender sipil), dengan awalan 0. | 01 hingga 52 atau 53 | 41 |
Hari: | |||
j | Tanggal dalam sebulan (tanpa awalan 0). | 1 hingga 31 | 10 |
d | Tanggal dalam sebulan (dengan awalan 0). | 01 hingga 31 | 10 |
z | Tanggal dalam setahun (dimulai dari 0). | 0 hingga 364 atau 365 | 283 |
D | Tiga huruf nama hari. | Sen hingga Min | Kam |
l
|
Nama hari lengkap. | Senin hingga Minggu | Kamis |
N | Tanggal dalam seminggu (menurut minggu ISO 8601). | 1 (untuk Senin) hingga 7 (untuk Minggu) | 4 |
Jam: | |||
a | am (dari 01:00:00 hingga 12:59:59) atau pm, dengan huruf kecil (untuk format 12-jam)). | am atau pm | am |
A | Sama dengan kode a di atas, dengan huruf besar
|
AM atau PM | AM |
g | Jam berformat 12-jam (tanpa awalan 0, menggunakan am/pm atau AM/PM). | 1 hingga 12 | 5 |
h | Jam berformat 12-jam (dengan awalan 0, menggunakan am/pm or AM/PM). | 01 hingga 12 | 05 |
G | Jam berformat 24-jam (tanpa awalan 0). | 0 hingga 23 | 5 |
H | Jam berformat 24-jam (tanpa awalan 0). | 00 hingga 23 | 05 |
Menit dan detik: | |||
i | Menit (dengan awalan 0). | 00 hingga 59 | 54 |
s | Detik (dengan awalan 0). | 00 hingga 59 | 39 |
U | Detik sejak 1 Januari 1970 00:00:00 GMT. | 0 hingga infiniti | 1728539679 |
Lain-lain: | |||
L | Tahun kabisat atau bukan | 1 jika tahun kabisat, 0 jika tidak. | 1 |
t | Jumlah hari dalam sebulan. | 28, 29, 30, atau 31 | 31 |
c | Tanggal berformat ISO 8601, sama dengan 2024-10-10UTC05:54:39+05:54|+0 052024uUTC05u, 10 +00002024-10-10T05:54:39+00:0031 2024 05:54:39 +000039. | string dengan panjang tertentu | 2024-10-10T05:54:39+00:00 |
r | Tanggal berformat RFC 2822, sama dengan Kam, 10 Okt 2024 05:54:39 +05:54|+0 052024uUTC05u, 10 +00002024-10-10T05:54:39+00:0031 2024 05:54:39 +000039. | string dengan panjang bervariasi | Thu, 10 Oct 2024 05:54:39 +0000 |
Ketentuan-ketentuan yang berlaku:
- Karakter format yang tidak dikenal akan ditampilkan apa adanya.
- Karakter-karakter dalam tanda kutip akan ditampilkan apa adanya tanpa diformat, contoh:
- Sekarang bulan Oktober → Sekarang bulan Januari
- 54'39" → 20'11"
- Karakter escape backslash seperti dalam fungsi date() di PHP's juga dikenal. \H menghasilkan huruf H, \" menghasilkan ".
Kode-kode format tambahan mungkin akan ditambahkan di masa mendatang. Fungsi "time" juga mengenal format waktu relatif dan absolut seperti "11 Desember" dan atau "+10 hours" yang bisa digunakan dalam konversi zona waktu.
Jika nilai dari eskpresi menghasilkan nol, maka <else> akan dikembalikan, selain itu <then> akan dikembalikan. <ekspresi> sama dengan pemakaian pada function expr
. Function ini merupakan bentuk pendek dari ..
Contoh:
- {{ #time:
l j F Y | 20070304
}}
menghasilkan "Minggu 4 Maret 2007"
- {{ #time:
l j F Y | 2007-03-04
}}
menghasilkan "Minggu 4 Maret 2007"
- {{ #time:
l j F Y | 2007/03/04
}}
menghasilkan "Minggu 4 Maret 2007"
- {{ #time:
l j F Y | 4 March 2007
}}
menghasilkan "Minggu 4 Maret 2007"
- {{ #time:
l j F Y | 4 March, 2007
}}
menghasilkan "Senin 4 Maret 2024" (!kesalahan: koma seharusnya tidak diikutkan)
- {{ #time:
l j F Y | March 4 2007
}}
menghasilkan "Minggu 4 Maret 2007"
- {{ #time:
l j F Y | March 4, 2007
}}
menghasilkan "Minggu 4 Maret 2007"
- {{ #time:
l j F Y | -32 days
}}
menghasilkan "Minggu 8 September 2024" (32 hari yang lalu)
- {{ #time:
H:i | +6 hours
}}
menghasilkan "11:54" (6 jam lebih awal dari UTC)
- {{ #time:
H:i | 8:15 +6 hours
}}
menghasilkan "14:15"
- {{ #time:
m/Y | -17 months
}}
menghasilkan "05/2023" (17 bulan yang lalu)
Jangkauan:
Tanggal tak lengkap
29 Februari:
Zona Waktu
#rel2abs:
sintaks:
- {{ #rel2abs:
<path>
}}
- {{ #rel2abs:
- {{ #rel2abs:
<path> | <base path>
}}
- {{ #rel2abs:
Fungsi rel2abs
adalah untuk mengkonversi pranala relatif ke pranala absolut. Pranala relatif adalah yang dimulai dengan '/', './', '../'. atau mengandung '/../' atau '/.' atau string '..' atau'.'.Jika base path diberikan, maka perlu ditulis dalam sintaks absolut.
Contoh:
- Di dalam
Bantuan:Foo/bar
,{{#rel2abs|../baz}}
menghasilkanBantuan:Foo/baz
- Di dalam
Bantuan:Foo
,{{#rel2abs|../baz}}
menghasilkanbaz
- Di dalam
Bantuan:Foo
,{{#rel2abs|../../baz}}
menghasilkanError: Invalid depth in path: "Help:Foo/../../baz" (tried to access a node above the root node)"
{{#rel2abs|../baz | Bantuan:Bar/foo}}
menghasilkanBantuan:Bar/baz
{{#rel2abs|Bantuan:Foo/bar/../baz}}
menghasilkanBantuan:Foo/baz
#titleparts:
sintaks:
- {{ #titleparts:
''namahalaman'' | ''jumlah_segmen'' | ''mulai_dari ''
}}
- {{ #titleparts:
- Jika mulai_dari dihilangkan, maka dianggap setara dengan 1
- Ruang Nama untuk namahalaman dikonversikan ke Ruang Nama bahasa lokal
Fungsi titleparts
ini akan menghasilkan bagian dari suatu judul halaman sesuai tingkat yang diisi pada parameter.
Contoh:
{{#titleparts:ABC/DEF/GHI|1}}
menghasilkanABC
{{#titleparts:ABC/DEF/GHI|2}}
menghasilkanABC/DEF
{{#titleparts:ABC/DEF/GHI|3}}
menghasilkanABC/DEF/GHI
Contoh dengan satu parameter numerik:
Contoh dengan dua parameter numerik:
Contoh dengan parameter negatif (artinya "dihitung dari kanan"):
#iferror:
- {{ #iferror:
''ekspresi'' | ''bermasalah'' | ''berhasil''
}}
- {{ #iferror:
Fungsi iferror
akan menghasilkan bermasalah jika ekspresi mengandung sebuah <strong class="error"> yang terkadang dihasilkan oleh #expr, #ifexpr, #time, #rel2abs, dan beberapa situasi lainnya di MediaWiki seperti kedalaman rekursif, dan loop templat. Fungsi ini berguna untuk menangkap masukan yang bermasalah.
Contoh:
{{#iferror:{{#expr:1+1}}|masukan bermasalah|ekspresi valid}}
menghasilkan ekspresi valid{{#iferror:{{#expr:1+Z}}|masukan bermasalah|ekspresi valid}}
menghasilkan masukan bermasalah