Bagikan melalui


Fungsi untai (karakter) untuk Bicep

Artikel ini menjelaskan fungsi Bicep untuk bekerja dengan untai (karakter).

base64

base64(inputString)

Mengembalikan representasi base64 dari string input.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
inputString Ya string Nilai yang dikembalikan sebagai representasi base64.

Nilai hasil

String yang berisi representasi base64.

Contoh

Contoh berikut menunjukkan cara menggunakan fungsi base64.

param stringData string = 'one, two, three'
param jsonFormattedData string = '{\'one\': \'a\', \'two\': \'b\'}'

var base64String = base64(stringData)
var base64Object = base64(jsonFormattedData)

output base64Output string = base64String
output toStringOutput string = base64ToString(base64String)
output toJsonOutput object = base64ToJson(base64Object)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
base64Output String b25lLCB0d28sIHRocmVl
toStringOutput String one, two, three
toJsonOutput Objek {"one": "a", "two": "b"}

base64ToJson

base64ToJson(base64Value)

Mengonversi representasi base64 menjadi objek JSON.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
base64Value Ya string Representasi base64 untuk dikonversi ke objek JSON.

Nilai hasil

Sebuah objek JSON.

Contoh

Contoh berikut menggunakan fungsi base64ToJson untuk mengonversi nilai base64:

param stringData string = 'one, two, three'
param jsonFormattedData string = '{\'one\': \'a\', \'two\': \'b\'}'

var base64String = base64(stringData)
var base64Object = base64(jsonFormattedData)

output base64Output string = base64String
output toStringOutput string = base64ToString(base64String)
output toJsonOutput object = base64ToJson(base64Object)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
base64Output String b25lLCB0d28sIHRocmVl
toStringOutput String one, two, three
toJsonOutput Objek {"one": "a", "two": "b"}

base64KeUntai

base64ToString(base64Value)

Mengonversi representasi base64 menjadi string.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
base64Value Ya string Representasi base64 untuk dikonversi ke string.

Nilai hasil

String dari nilai base64 yang dikonversi.

Contoh

Contoh berikut menggunakan fungsi base64ToString untuk mengonversi nilai base64:

param stringData string = 'one, two, three'
param jsonFormattedData string = '{\'one\': \'a\', \'two\': \'b\'}'

var base64String = base64(stringData)
var base64Object = base64(jsonFormattedData)

output base64Output string = base64String
output toStringOutput string = base64ToString(base64String)
output toJsonOutput object = base64ToJson(base64Object)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
base64Output String b25lLCB0d28sIHRocmVl
toStringOutput String one, two, three
toJsonOutput Objek {"one": "a", "two": "b"}

concat

concat(arg1, arg2, arg3, ...)

Menggabungkan beberapa nilai string dan mengembalikan string yang digabungkan, atau menggabungkan beberapa array dan mengembalikan array yang digabungkan. Untuk meningkatkan keterbacaan, gunakan interpolasi string alih-alih concat() fungsi . Namun, dalam beberapa kasus seperti penggantian string dalam string multibaris, Anda mungkin perlu kembali menggunakan concat() fungsi atau replace() fungsi .

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
arg1 Ya string atau array String atau array pertama untuk perangkaian.
lebih banyak argumen No string atau array Lebih banyak string atau array secara berurutan untuk perangkaian.

Fungsi ini dapat mengambil sejumlah argumen, dan dapat menerima string atau array untuk parameter. Namun, Anda tidak dapat menyediakan array dan string untuk parameter. String hanya digabungkan dengan string lainnya.

Nilai hasil

String atau array nilai yang digabungkan.

Contoh

Contoh berikut menunjukkan perbandingan antara menggunakan interpolasi dan menggunakan concat() fungsi . Dua output mengembalikan nilai yang sama.

param prefix string = 'prefix'

output concatOutput string = concat(prefix, 'And', uniqueString(resourceGroup().id))
output interpolationOutput string = '${prefix}And${uniqueString(resourceGroup().id)}'

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
concatOutput String prefixAnd5yj4yjf5mbg72
interpolationOutput String prefixAnd5yj4yjf5mbg72

Interpolasi saat ini tidak didukung dalam string multi-line. Contoh berikut menunjukkan perbandingan antara menggunakan interpolasi dan menggunakan concat() fungsi .

var blocked = 'BLOCKED'

output concatOutput string = concat('''interpolation
is ''', blocked)
output interpolationOutput string = '''interpolation
is ${blocked}'''

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
concatOutput String interpolasi\nis DIBLOKIR
interpolationOutput String interpolasi\nis ${blocked}

mengandung

contains(container, itemToFind)

Memeriksa apakah array berisi nilai, objek berisi kunci, atau untai (karakter) berisi sub-untai (karakter). Perbandingan untai (karakter) peka terhadap huruf besar/kecil. Namun, ketika pengujian, jika objek berisi kunci, perbandingannya tidak peka huruf besar/kecil.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
kontainer Ya array, objek, atau string Nilai yang berisi nilai untuk ditemukan.
itemToFind Ya string atau int Nilai untuk ditemukan.

Nilai hasil

Benar jika item ditemukan; jika tidak, Salah.

Contoh

Contoh berikut menunjukkan cara menggunakan berisi dengan jenis yang berbeda:

param stringToTest string = 'OneTwoThree'
param objectToTest object = {
  one: 'a'
  two: 'b'
  three: 'c'
}
param arrayToTest array = [
  'one'
  'two'
  'three'
]

output stringTrue bool = contains(stringToTest, 'e')
output stringFalse bool = contains(stringToTest, 'z')
output objectTrue bool = contains(objectToTest, 'one')
output objectFalse bool = contains(objectToTest, 'a')
output arrayTrue bool = contains(arrayToTest, 'three')
output arrayFalse bool = contains(arrayToTest, 'four')

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
stringTrue Bool Benar
stringFalse Bool Salah
objectTrue Bool Benar
objectFalse Bool Salah
arrayTrue Bool Benar
arrayFalse Bool Salah

dataUri

dataUri(stringToConvert)

Mengonversi nilai menjadi URI data.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
stringToConvert Ya string Nilai untuk dikonversi menjadi URI data.

Nilai hasil

String yang diformat sebagai URI data.

Contoh

Contoh berikut mengonversi nilai menjadi data URI, dan mengonversi data URI menjadi untai (karakter):

param stringToTest string = 'Hello'
param dataFormattedString string = 'data:;base64,SGVsbG8sIFdvcmxkIQ=='

output dataUriOutput string = dataUri(stringToTest)
output toStringOutput string = dataUriToString(dataFormattedString)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
dataUriOutput String data:text/plain;charset=utf8;base64,SGVsbG8=
toStringOutput String Hello, World!

dataUriToString

dataUriToString(dataUriToConvert)

Mengonversi nilai berformat URI data menjadi string.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
dataUriToConvert Ya string Nilai URI data untuk dikonversi.

Nilai hasil

String yang berisi nilai yang dikonversi.

Contoh

Contoh berikut mengonversi nilai menjadi data URI, dan mengonversi data URI menjadi untai (karakter):

param stringToTest string = 'Hello'
param dataFormattedString string = 'data:;base64,SGVsbG8sIFdvcmxkIQ=='

output dataUriOutput string = dataUri(stringToTest)
output toStringOutput string = dataUriToString(dataFormattedString)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
dataUriOutput String data:text/plain;charset=utf8;base64,SGVsbG8=
toStringOutput String Hello, World!

kosong

empty(itemToTest)

Menentukan apakah array, objek, atau untai (karakter) kosong.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
itemToTest Ya array, objek, atau string Nilai untuk memeriksa apakah nilainya kosong.

Nilai hasil

Kembalikan Benar jika nilainya kosong; jika tidak, Salah.

Contoh

Contoh berikut ini memeriksa apakah array, objek, dan string kosong.

param testArray array = []
param testObject object = {}
param testString string = ''

output arrayEmpty bool = empty(testArray)
output objectEmpty bool = empty(testObject)
output stringEmpty bool = empty(testString)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
arrayEmpty Bool Benar
objectEmpty Bool Benar
stringEmpty Bool Benar

endsWith

endsWith(stringToSearch, stringToFind)

Menentukan apakah untai berakhir dengan nilai. Perbandingannya adalah tidak peka huruf besar/kecil.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
stringToSearch Ya string Nilai yang berisi nilai untuk ditemukan.
stringToFind Ya string Nilai untuk ditemukan.

Nilai hasil

Benar jika karakter terakhir atau karakter string cocok dengan nilai; jika tidak, Salah.

Contoh

Contoh berikut memperlihatkan cara menggunakan fungsi startsWith dan endsWith:

output startsTrue bool = startsWith('abcdef', 'ab')
output startsCapTrue bool = startsWith('abcdef', 'A')
output startsFalse bool = startsWith('abcdef', 'e')
output endsTrue bool = endsWith('abcdef', 'ef')
output endsCapTrue bool = endsWith('abcdef', 'F')
output endsFalse bool = endsWith('abcdef', 'e')

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
startsTrue Bool Benar
startsCapTrue Bool Benar
startsFalse Bool Salah
endsTrue Bool Benar
endsCapTrue Bool Benar
endsFalse Bool Salah

pertama

first(arg1)

Mengembalikan karakter pertama dari string, atau elemen pertama array. Jika string kosong diberikan, fungsi akan menghasilkan string kosong. Dalam kasus array kosong, fungsi mengembalikan null.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
arg1 Ya array atau string Nilai untuk mengambil elemen atau karakter pertama.

Nilai hasil

String karakter pertama, atau jenis (string, int, array, atau objek) dari elemen pertama dalam array.

Contoh

Contoh berikut menunjukkan cara menggunakan fungsi pertama dengan array dan string.

param arrayToTest array = [
  'one'
  'two'
  'three'
]

output arrayOutput string = first(arrayToTest)
output stringOutput string = first('One Two Three')

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
arrayOutput String satu
stringOutput String O

format

format(formatString, arg1, arg2, ...)

Membuat string yang diformat dari nilai input.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
formatString Ya string String format komposit.
arg1 Ya string, bilangan bulat, atau boolean Nilai yang akan disertakan dalam string yang diformat.
argumen tambahan No string, bilangan bulat, atau boolean Nilai yang akan disertakan dalam string yang diformat.

Keterangan

Gunakan fungsi ini untuk memformat untai (karakter) di file Bicep Anda. Ini menggunakan opsi pemformatan yang sama dengan metode System.String.Format di .NET.

Contoh

Contoh berikut memperlihatkan cara menggunakan fungsi format.

param greeting string = 'Hello'
param name string = 'User'
param numberToFormat int = 8175133
param objectToFormat object = { prop: 'value' }

output formatTest string = format('{0}, {1}. Formatted number: {2:N0}', greeting, name, numberToFormat)
output formatObject string = format('objectToFormat: {0}', objectToFormat)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
formatTest String Hello, User. Formatted number: 8,175,133
formatObject String objectToFormat: {'prop':'value'}

guid

guid(baseString, ...)

Membuat nilai dalam format pengidentifikasi unik global berdasarkan nilai yang disediakan sebagai parameter.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
baseString Ya string Nilai yang digunakan dalam fungsi hash untuk membuat GUID.
parameter tambahan sesuai kebutuhan No string Anda dapat menambahkan string sebanyak yang diperlukan untuk membuat nilai yang menentukan tingkat keunikan.

Keterangan

Fungsi ini berguna ketika Anda perlu membuat nilai dalam format pengidentifikasi yang unik secara global. Anda menyediakan nilai parameter yang membatasi cakupan keunikan untuk hasilnya. Anda dapat menentukan apakah nama tersebut unik hingga ke langganan, grup sumber daya, atau penyebaran.

Nilai yang dikembalikan bukan string acak, melainkan hasil dari fungsi hash pada parameter. Nilai yang dikembalikan memiliki panjang 36 karakter. Ini tidak unik secara global. Untuk membuat GUID baru yang tidak didasarkan pada nilai hash parameter, gunakan fungsi newGuid.

Catatan

Urutan parameter mempengaruhi nilai yang dikembalikan. Contohnya:

guid('hello', 'world') dan guid('world', 'hello')

Jangan mengembalikan nilai yang sama.

Contoh berikut memperlihatkan cara menggunakan guid untuk membuat nilai unik untuk tingkat yang umum digunakan.

Cakupan unik untuk langganan

guid(subscription().subscriptionId)

Cakupan unik untuk grup sumber daya

guid(resourceGroup().id)

Cakupan unik untuk penyebaran untuk grup sumber daya

guid(resourceGroup().id, deployment().name)

Fungsi ini guid mengimplementasikan algoritma dari RFC 4122 ยง4,3. Sumber asli dapat ditemukan di GuidUtility dengan beberapa modifikasi.

Nilai hasil

String yang berisi 36 karakter dalam format pengidentifikasi unik global.

Contoh

Contoh berikut mengembalikan hasil dari guid:

output guidPerSubscription string = guid(subscription().subscriptionId)
output guidPerResourceGroup string = guid(resourceGroup().id)
output guidPerDeployment string = guid(resourceGroup().id, deployment().name)

indexOf

indexOf(stringToSearch, stringToFind)

Mengembalikan posisi pertama dari nilai dalam string. Perbandingannya adalah tidak peka huruf besar/kecil.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
stringToSearch Ya string Nilai yang berisi nilai untuk ditemukan.
stringToFind Ya string Nilai untuk ditemukan.

Nilai hasil

Bilangan bulat yang mewakili posisi item untuk ditemukan. Nilainya berbasis nol. Jika item tidak ditemukan, -1 dikembalikan.

Contoh

Contoh berikut memperlihatkan cara menggunakan fungsi indexOf dan lastIndexOf:

output firstT int = indexOf('test', 't')
output lastT int = lastIndexOf('test', 't')
output firstString int = indexOf('abcdef', 'CD')
output lastString int = lastIndexOf('abcdef', 'AB')
output notFound int = indexOf('abcdef', 'z')

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
firstT Int 0
lastT Int 3
firstString Int 2
lastString Int 0
notFound Int -1

join

join(inputArray, delimiter)

Menggabungkan array string menjadi satu string, dipisahkan menggunakan pemisah.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
inputArray Ya Sebuah array dari string. Array string untuk bergabung.
delimiter Ya Pemisah yang digunakan untuk memisahkan string.

Nilai hasil

String .

Contoh

Contoh berikut menggabungkan array string input menjadi string yang dibatasi oleh koma atau titik koma.

var arrayString = [
  'one'
  'two'
  'three'
]

output firstOutput string = join(arrayString, ',')
output secondOutput string = join(arrayString, ';')

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
firstOutput String "satu,dua,tiga"
secondOutput String "satu;dua;tiga"

Fungsi ini memerlukan Bicep CLI versi 0.8.X atau yang lebih tinggi.

json

json(arg1)

Mengonversi string JSON yang valid menjadi jenis data JSON. Untuk informasi selengkapnya, lihat fungsi json.

Namespace: sys.

terakhir

last(arg1)

Mengembalikan karakter terakhir dari string, atau elemen terakhir dari array.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
arg1 Ya array atau string Nilai untuk mengambil elemen atau karakter terakhir.

Nilai hasil

String karakter terakhir, atau jenis (string, int, array, atau objek) dari elemen pertama dalam array.

Contoh

Contoh berikut menunjukkan cara menggunakan fungsi terakhir dengan array dan string.

param arrayToTest array = [
  'one'
  'two'
  'three'
]

output arrayOutput string = last(arrayToTest)
output stringOutput string = last('One Two Three')

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
arrayOutput String tiga
stringOutput String e

lastIndexOf

lastIndexOf(stringToSearch, stringToFind)

Mengembalikan posisi terakhir dari nilai dalam string. Perbandingannya adalah tidak peka huruf besar/kecil.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
stringToSearch Ya string Nilai yang berisi nilai untuk ditemukan.
stringToFind Ya string Nilai untuk ditemukan.

Nilai hasil

Bilangan bulat yang mewakili posisi item untuk ditemukan. Nilainya berbasis nol. Jika item tidak ditemukan, -1 dikembalikan.

Contoh

Contoh berikut menunjukkan cara penggunaan fungsi indexOf dan lastIndexOf:

output firstT int = indexOf('test', 't')
output lastT int = lastIndexOf('test', 't')
output firstString int = indexOf('abcdef', 'CD')
output lastString int = lastIndexOf('abcdef', 'AB')
output notFound int = indexOf('abcdef', 'z')

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
firstT Int 0
lastT Int 3
firstString Int 2
lastString Int 0
notFound Int -1

length

length(string)

Mengembalikan jumlah karakter dalam string, elemen dalam array, atau properti tingkat akar dalam objek.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
arg1 Ya array, untai (karakter), atau objek Array yang digunakan untuk mendapatkan jumlah elemen, untai (karakter) yang digunakan untuk mendapatkan jumlah karakter, atau objek yang digunakan untuk mendapatkan jumlah properti tingkat root.

Nilai hasil

Int.

Contoh

Contoh berikut memperlihatkan cara menggunakan panjang dengan array dan string:

param arrayToTest array = [
  'one'
  'two'
  'three'
]
param stringToTest string = 'One Two Three'
param objectToTest object = {
  propA: 'one'
  propB: 'two'
  propC: 'three'
  propD: {
    'propD-1': 'sub'
    'propD-2': 'sub'
  }
}

output arrayLength int = length(arrayToTest)
output stringLength int = length(stringToTest)
output objectLength int = length(objectToTest)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
arrayLength Int 3
stringLength Int 13
objectLength Int 4

newGuid

newGuid()

Mengembalikan nilai dalam format pengidentifikasi unik global. Fungsi ini hanya dapat digunakan dalam nilai default untuk parameter.

Namespace: sys.

Keterangan

Anda hanya bisa menggunakan fungsi ini dalam ekspresi untuk nilai default parameter. Menggunakan fungsi ini di tempat lain dalam file Bicep mengembalikan kesalahan. Fungsi ini tidak diizinkan di bagian lain file Bicep karena mengembalikan nilai yang berbeda setiap kali disebut. Menyebarkan file Bicep yang sama dengan parameter yang sama tidak akan menghasilkan hasil yang sama secara andal.

Fungsi newGuid berbeda dari fungsi guid karena tidak mengambil parameter apa pun. Saat Anda memanggil guid dengan parameter yang sama, guid akan mengembalikan pengidentifikasi yang sama setiap waktu. Gunakan guid saat Anda perlu menghasilkan GUID yang sama untuk lingkungan tertentu. Gunakan newGuid saat Anda memerlukan pengidentifikasi yang berbeda setiap waktu, seperti menyebarkan sumber daya ke lingkungan pengujian.

Fungsi newGuid menggunakan struktur Guid dalam .NET Framework untuk menghasilkan pengidentifikasi yang unik secara global.

Jika Anda menggunakan opsi untuk menyebar ulang penyebaran yang berhasil sebelumnya, dan penyebaran sebelumnya menyertakan parameter yang menggunakan newGuid, parameter tidak dievaluasi ulang. Sebaliknya, nilai parameter dari penyebaran sebelumnya secara otomatis digunakan kembali dalam penyebaran putar kembali.

Dalam lingkungan pengujian, Anda mungkin perlu berulang kali menyebarkan sumber daya yang hanya hidup untuk waktu yang singkat. Daripada mengonstruksi nama unik, Anda dapat menggunakan newGuid dengan uniqueString untuk membuat nama unik.

Hati-hati menyebar ulang file Bicep yang bergantung pada fungsi newGuid untuk nilai default. Ketika Anda menyebar ulang dan tidak memberikan nilai untuk parameter, fungsi tersebut dievaluasi kembali. Jika Anda ingin memperbarui sumber daya yang ada daripada membuat yang baru, berikan nilai parameter dari penyebaran sebelumnya.

Nilai hasil

String yang berisi 36 karakter dalam format pengidentifikasi unik global.

Contoh

Contoh berikut memperlihatkan parameter dengan pengidentifikasi baru.

param guidValue string = newGuid()

output guidOutput string = guidValue

Keluaran dari contoh sebelumnya bervariasi untuk setiap penyebaran tetapi akan mirip dengan:

Nama Jenis Nilai
guidOutput string b76a51fc-bd72-4a77-b9a2-3c29e7d2e551

Contoh berikut menggunakan fungsi newGuid untuk membuat nama unik untuk akun penyimpanan. File Bicep ini mungkin berfungsi untuk lingkungan pengujian tempat akun penyimpanan berada untuk waktu yang singkat dan tidak disebar ulang.

param guidValue string = newGuid()

var storageName = 'storage${uniqueString(guidValue)}'

resource myStorage 'Microsoft.Storage/storageAccounts@2018-07-01' = {
  name: storageName
  location: 'West US'
  sku: {
    name: 'Standard_LRS'
  }
  kind: 'StorageV2'
  properties: {}
}

output nameOutput string = storageName

Keluaran dari contoh sebelumnya bervariasi untuk setiap penyebaran tetapi akan mirip dengan:

Nama Jenis Nilai
nameOutput string storagenziwvyru7uxie

padLeft

padLeft(valueToPad, totalLength, paddingCharacter)

Mengembalikan string rata kanan dengan menambahkan karakter ke kiri hingga mencapai total panjang yang ditentukan.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
valueToPad Ya string atau int Nilai untuk rata kanan.
totalLength Ya int Jumlah total karakter dalam string yang dikembalikan.
paddingCharacter No karakter tunggal Karakter yang digunakan untuk pengisi kiri hingga total panjang tercapai. Nilai defaultnya adalah sebuah spasi.

Jika string asli lebih panjang dari jumlah karakter yang diisi, tidak ada karakter yang ditambahkan.

Nilai hasil

String dengan setidaknya jumlah karakter yang ditentukan.

Contoh

Contoh berikut memperlihatkan cara mengisi nilai parameter yang disediakan pengguna dengan menambahkan karakter nol hingga nilai parameter mencapai jumlah total karakter.

param testString string = '123'

output stringOutput string = padLeft(testString, 10, '0')

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
stringOutput String 0000000123

mengganti

replace(originalString, oldString, newString)

Mengembalikan string baru dengan semua contoh dari satu string yang digantikan oleh string lain.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
originalString Ya string Nilai yang memiliki semua instans dari satu string digantikan oleh string lain.
oldString Ya string String yang akan dihapus dari string asli.
newString Ya string String untuk ditambahkan menggantikan string yang dihapus.

Nilai hasil

String dengan karakter yang diganti.

Contoh

Contoh berikut memperlihatkan cara menghapus semua tanda hubung dari untai (karakter) yang disediakan pengguna, dan cara mengganti bagian untai (karakter) dengan untai (karakter) lain.

param testString string = '123-123-1234'

output firstOutput string = replace(testString, '-', '')
output secondOutput string = replace(testString, '1234', 'xxxx')

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
firstOutput String 1231231234
secondOutput String 123-123-xxxx

skip

skip(originalValue, numberToSkip)

Mengembalikan string dengan semua karakter setelah jumlah karakter yang ditentukan, atau array dengan semua elemen setelah jumlah elemen yang ditentukan.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
originalValue Ya array atau string Array atau string yang digunakan untuk melompati.
numberToSkip Ya int Jumlah elemen atau karakter yang akan dilompati. Jika nilai ini adalah 0 atau kurang, semua elemen atau karakter dalam nilai dikembalikan. Jika lebih besar dari panjang array atau string, array atau string kosong akan dikembalikan.

Nilai hasil

Array atau string.

Contoh

Contoh berikut melompati jumlah elemen yang ditentukan dalam array, dan jumlah karakter yang ditentukan dalam string.

param testArray array = [
  'one'
  'two'
  'three'
]
param elementsToSkip int = 2
param testString string = 'one two three'
param charactersToSkip int = 4

output arrayOutput array = skip(testArray, elementsToSkip)
output stringOutput string = skip(testString, charactersToSkip)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
arrayOutput Array ["three"]
stringOutput String dua tiga

belah

split(inputString, delimiter)

Mengembalikan array string yang berisi substring dari string input yang dipisah oleh pemisah yang ditentukan.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
inputString Ya string String untuk dipisahkan.
delimiter Ya string atau array string Pemisah yang digunakan untuk memisahkan string.

Nilai hasil

Array string.

Contoh

Contoh berikut memisahkan untai (karakter) input dengan koma, dan dengan koma atau titik koma.

param firstString string = 'one,two,three'
param secondString string = 'one;two,three'

var delimiters = [
  ','
  ';'
]

output firstOutput array = split(firstString, ',')
output secondOutput array = split(secondString, delimiters)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
firstOutput Array ["one", "two", "three"]
secondOutput Array ["one", "two", "three"]

startsWith

startsWith(stringToSearch, stringToFind)

Menentukan apakah string memulai dengan nilai. Perbandingannya adalah tidak peka huruf besar/kecil.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
stringToSearch Ya string Nilai yang berisi nilai untuk ditemukan.
stringToFind Ya string Nilai untuk ditemukan.

Nilai hasil

Benar jika karakter pertama atau karakter string cocok dengan nilai; jika tidak, Salah.

Contoh

Contoh berikut memperlihatkan cara menggunakan fungsi startsWith dan endsWith:

output startsTrue bool = startsWith('abcdef', 'ab')
output startsCapTrue bool = startsWith('abcdef', 'A')
output startsFalse bool = startsWith('abcdef', 'e')
output endsTrue bool = endsWith('abcdef', 'ef')
output endsCapTrue bool = endsWith('abcdef', 'F')
output endsFalse bool = endsWith('abcdef', 'e')

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
startsTrue Bool Benar
startsCapTrue Bool Benar
startsFalse Bool Salah
endsTrue Bool Benar
endsCapTrue Bool Benar
endsFalse Bool Salah

string

string(valueToConvert)

Mengonversi nilai yang ditentukan menjadi string. String dikembalikan apa adanya. Jenis lain dikonversi ke representasi JSON yang setara. Jika Anda perlu mengonversi string ke JSON, yaitu kutip/keluarkan, Anda dapat menggunakan substring(string([value]), 1, length(string([value]) - 2).

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
valueToConvert Ya Mana pun Nilai untuk dikonversi menjadi string. Jenis nilai apa pun dapat dikonversi, termasuk objek dan array.

Nilai hasil

String dari nilai yang dikonversi.

Contoh

Contoh berikut memperlihatkan cara mengonversi jenis nilai yang berbeda menjadi untai (karakter):

param testObject object = {
  valueA: 10
  valueB: 'Example Text'
}
param testArray array = [
  '\'a\''
  '"b"'
  '\\c\\'
]
param testInt int = 5
param testString string = 'foo " \' \\'

output objectOutput string = string(testObject)
output arrayOutput string = string(testArray)
output intOutput string = string(testInt)
output stringOutput string = string(testString)
output stringEscapedOutput string = substring(string([testString]), 1, length(string([testString])) - 2)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
objectOutput String {"valueA":10,"valueB":"Example Text"}
arrayOutput String ["'a'","\"b\"","\\c\\"]
intOutput String 5
stringOutput String foo " ' \
stringEscapedOutput String "foo \" ' \\"

substring

substring(stringToParse, startIndex, length)

Mengembalikan substring yang dimulai pada posisi karakter yang ditentukan dan berisi jumlah karakter yang ditentukan.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
stringToParse Ya string String asli dari substring yang diekstrak.
startIndex No int Posisi karakter awal berbasis nol untuk substring.
length No int Jumlah karakter untuk substring. Harus merujuk ke lokasi dalam string. Harus nol atau lebih besar. Jika dihilangkan, sisa string dari posisi awal akan ditampilkan.

Nilai hasil

Substring. Atau, string kosong jika panjangnya nol.

Keterangan

Fungsi gagal ketika substring meluas melampaui akhir string, atau ketika panjang kurang dari nol. Contoh berikut gagal dengan kesalahan "Parameter indeks dan panjang harus merujuk ke lokasi dalam string. Parameter indeks: '0', parameter panjang: '11', panjang parameter string: '10'.".

param inputString string = '1234567890'

var prefix = substring(inputString, 0, 11)

Contoh

Contoh berikut mengekstrak substring dari parameter.

param testString string = 'one two three'
output substringOutput string = substring(testString, 4, 3)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
substringOutput String two

take

take(originalValue, numberToTake)

Mengembalikan string dengan jumlah karakter yang ditentukan dari awal string, atau array dengan jumlah elemen yang ditentukan dari awal array.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
originalValue Ya array atau string Array atau string untuk mengambil elemen.
numberToTake Ya int Jumlah elemen atau karakter yang akan diambil. Jika nilai ini adalah 0 atau kurang, array atau string kosong dikembalikan. Jika lebih besar dari panjang array atau string yang diberikan, semua elemen dalam array atau string dikembalikan.

Nilai hasil

Array atau string.

Contoh

Contoh berikut mengambil jumlah elemen yang ditentukan dari array, dan karakter dari string.

param testArray array = [
  'one'
  'two'
  'three'
]
param elementsToTake int = 2
param testString string = 'one two three'
param charactersToTake int = 2

output arrayOutput array = take(testArray, elementsToTake)
output stringOutput string = take(testString, charactersToTake)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
arrayOutput Array ["one", "two"]
stringOutput String aktif

toLower

toLower(stringToChange)

Mengonversi string yang ditentukan menjadi huruf kecil.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
stringToChange Ya string Nilai untuk dikonversi ke huruf kecil.

Nilai hasil

String untuk dikonversi ke huruf kecil.

Contoh

Contoh berikut mengonversi nilai parameter menjadi huruf kecil dan menjadi huruf besar.

param testString string = 'One Two Three'

output toLowerOutput string = toLower(testString)
output toUpperOutput string = toUpper(testString)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
toLowerOutput String one two three
toLowerOutput String ONE TWO THREE

toUpper

toUpper(stringToChange)

Mengonversi string yang ditentukan menjadi huruf besar.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
stringToChange Ya string Nilai untuk dikonversi ke huruf besar.

Nilai hasil

String untuk dikonversi ke huruf besar.

Contoh

Contoh berikut mengonversi nilai parameter menjadi huruf kecil dan menjadi huruf besar.

param testString string = 'One Two Three'

output toLowerOutput string = toLower(testString)
output toUpperOutput string = toUpper(testString)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
toLowerOutput String one two three
toLowerOutput String ONE TWO THREE

trim

trim(stringToTrim)

Menghapus semua karakter spasi putih berikutnya dan jarak antar baris dari string yang ditentukan.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
stringToTrim Ya string Nilai untuk dipangkas.

Nilai hasil

String tanpa karakter spasi putih berikutnya dan jarak antar baris.

Contoh

Contoh berikut memangkas karakter spasi putih dari parameter.

param testString string = '    one two three   '

output return string = trim(testString)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
return String one two three

uniqueString

uniqueString(baseString, ...)

Membuat string hash deterministik berdasarkan nilai yang disediakan sebagai parameter.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
baseString Ya string Nilai yang digunakan dalam fungsi hash untuk membuat string unik.
parameter tambahan sesuai kebutuhan No string Anda dapat menambahkan string sebanyak yang diperlukan untuk membuat nilai yang menentukan tingkat keunikan.

Keterangan

Fungsi ini berguna ketika Anda perlu membuat nama unik untuk sumber daya. Anda menyediakan nilai parameter yang membatasi cakupan keunikan untuk hasilnya. Anda dapat menentukan apakah nama tersebut unik hingga ke langganan, grup sumber daya, atau penyebaran.

Nilai yang dikembalikan bukan string acak, melainkan hasil dari fungsi hash pada parameter. Nilai yang dikembalikan memiliki panjang 13 karakter. Ini tidak unik secara global. Anda mungkin ingin menggabungkan nilai dengan prefiks dari konvensi penamaan Anda untuk membuat nama yang bermakna. Contoh berikut memperlihatkan format nilai yang dikembalikan. Nilai aktual bervariasi menurut parameter yang disediakan.

tcvhiyu5h2o5o

Contoh berikut memperlihatkan cara menggunakan uniqueString untuk membuat nilai unik untuk tingkat yang umum digunakan.

Cakupan unik untuk langganan

uniqueString(subscription().subscriptionId)

Cakupan unik untuk grup sumber daya

uniqueString(resourceGroup().id)

Cakupan unik untuk penyebaran untuk grup sumber daya

uniqueString(resourceGroup().id, deployment().name)

Contoh berikut memperlihatkan cara membuat nama unik untuk akun penyimpanan berdasarkan grup sumber daya Anda. Di dalam grup sumber daya, namanya tidak unik jika dikonstruksi dengan cara yang sama.

resource mystorage 'Microsoft.Storage/storageAccounts@2018-07-01' = {
  name: 'storage${uniqueString(resourceGroup().id)}'
  ...
}

Jika Anda perlu membuat nama unik baru setiap kali Anda menyebarkan file Bicep, dan tidak bermaksud memperbarui sumber daya, Anda dapat menggunakan fungsi utcNow dengan uniqueString. Anda dapat menggunakan pendekatan ini di lingkungan pengujian. Misalnya, lihat utcNow. Perhatikan bahwa fungsi utcNow hanya dapat digunakan dalam ekspresi untuk nilai default parameter.

Nilai hasil

String berisi 13 karakter.

Contoh

Contoh berikut mengembalikan hasil dari uniquestring:

output uniqueRG string = uniqueString(resourceGroup().id)
output uniqueDeploy string = uniqueString(resourceGroup().id, deployment().name)

uri

uri(baseUri, relativeUri)

Membuat URI absolut dengan menggabungkan baseUri dan string relativeUri.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
baseUri Ya string String uri dasar. Berhati-hatilah untuk mengamati perilaku mengenai penanganan garis miring berikutnya ('/'), seperti yang dijelaskan mengikuti tabel ini.
relativeUri Ya string String uri relatif untuk ditambahkan ke string uri dasar.
  • Jika baseUri berakhir dengan garis miring di belakang, hasilnya hanya baseUri diikuti oleh relativeUri.

  • Jika baseUri tidak berakhir dengan garis miring di belakang salah satu dari dua hal yang terjadi.

    • Jika baseUri tidak memiliki garis miring sama sekali (selain dari "//" di dekat bagian depan) hasilnya hanya baseUri diikuti oleh relativeUri.

    • Jika baseUri memiliki beberapa garis miring, tetapi tidak berakhir dengan garis miring, semuanya dari garis miring terakhir dan seterusnya dihapus dari baseUri dan hasilnya adalah baseUri diikuti oleh relatifUri.

Berikut adalah beberapa contoh:

uri('http://contoso.org/firstpath', 'myscript.sh') -> http://contoso.org/myscript.sh
uri('http://contoso.org/firstpath/', 'myscript.sh') -> http://contoso.org/firstpath/myscript.sh
uri('http://contoso.org/firstpath/azuredeploy.json', 'myscript.sh') -> http://contoso.org/firstpath/myscript.sh
uri('http://contoso.org/firstpath/azuredeploy.json/', 'myscript.sh') -> http://contoso.org/firstpath/azuredeploy.json/myscript.sh

Untuk detail lengkapnya, parameter baseUri dan relativeUri diselesaikan seperti yang ditentukan dalam RFC 3986, bagian 5.

Nilai hasil

String yang mewakili URI absolut untuk nilai dasar dan relatif.

Contoh

Contoh berikut memperlihatkan cara menggunakan uri, uriComponent, dan uriComponentToString:

var uriFormat = uri('http://contoso.com/resources/', 'nested/azuredeploy.json')
var uriEncoded = uriComponent(uriFormat)

output uriOutput string = uriFormat
output componentOutput string = uriEncoded
output toStringOutput string = uriComponentToString(uriEncoded)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
uriOutput String http://contoso.com/resources/nested/azuredeploy.json
componentOutput String http%3A%2F%2Fcontoso.com%2Fresources%2Fnested%2Fazuredeploy.json
toStringOutput String http://contoso.com/resources/nested/azuredeploy.json

uriComponent

uricomponent(stringToEncode)

Mengkodekan URI.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
stringToEncode Ya string Nilai yang akan dikodekan.

Nilai hasil

String nilai yang dikodekan URI.

Contoh

Contoh berikut memperlihatkan cara menggunakan uri, uriComponent, dan uriComponentToString:

var uriFormat = uri('http://contoso.com/resources/', 'nested/azuredeploy.json')
var uriEncoded = uriComponent(uriFormat)

output uriOutput string = uriFormat
output componentOutput string = uriEncoded
output toStringOutput string = uriComponentToString(uriEncoded)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
uriOutput String http://contoso.com/resources/nested/azuredeploy.json
componentOutput String http%3A%2F%2Fcontoso.com%2Fresources%2Fnested%2Fazuredeploy.json
toStringOutput String http://contoso.com/resources/nested/azuredeploy.json

uriComponentToString

uriComponentToString(uriEncodedString)

Mengembalikan string nilai yang dikodekan URI.

Namespace: sys.

Parameter

Parameter Wajib Tipe Deskripsi
uriEncodedString Ya string Nilai yang dikodekan URI untuk dikonversi menjadi string.

Nilai hasil

String yang dikodekan dari nilai yang dikodekan URI.

Contoh

Contoh berikut memperlihatkan cara menggunakan uri, uriComponent, dan uriComponentToString:

var uriFormat = uri('http://contoso.com/resources/', 'nested/azuredeploy.json')
var uriEncoded = uriComponent(uriFormat)

output uriOutput string = uriFormat
output componentOutput string = uriEncoded
output toStringOutput string = uriComponentToString(uriEncoded)

Output dari contoh sebelumnya dengan nilai default adalah:

Nama Jenis Nilai
uriOutput String http://contoso.com/resources/nested/azuredeploy.json
componentOutput String http%3A%2F%2Fcontoso.com%2Fresources%2Fnested%2Fazuredeploy.json
toStringOutput String http://contoso.com/resources/nested/azuredeploy.json

Langkah berikutnya