mixmatch - kod ve grafik fonksiyonu
mixmatch fonksiyonu, ilk parametreyi ondan sonra gelen tüm parametrelerle karşılaştırır ve eşleşen ifadelerin sayısal konumunu döndürür. Karşılaştırma büyük/küçük harf duyarlı değildir.
Syntax:
mixmatch( str, expr1 [ , expr2,...exprN ])
Stockholm, mixmatch fonksiyonundaki ifade listesinde yer almadığından, aşağıdaki tablodaki ilk ifade, Stockholm için 0 değerini döndürür. mixmatch karşılaştırması büyük/küçük harf duyarlı olmadığından 'Zurich' için 4 değerini döndürür.
Şehirler | mixmatch( Cities,'Toronto','Boston','Beijing','Zurich') | mixmatch( Cities,'Toronto','Boston','Beijing','Stockholm','Zurich') |
---|---|---|
Beijing |
3 |
3 |
Boston | 2 | 2 |
Stockholm | 0 | 4 |
Toronto | 1 | 1 |
zurich | 4 | 5 |
Bir ifade için özel bir sıralama gerçekleştirmek üzere mixmatch öğesini kullanabilirsiniz.
Varsayılan olarak sütunlar, verilere bağlı olarak sayısal ve alfabetik şekilde sıralanır.
Şehirler |
---|
Beijing |
Boston |
Stockholm |
Toronto |
zurich |
Sıralamayı değiştirmek için aşağıdakileri yapın:
- Özellikler panelinde grafiğiniz için Sıralama bölümünü açın.
- Özel sıralama yapmak istediğiniz sütun için otomatik sıralamayı kapatın.
- Sayısal olarak sırala ve Alfabetik olarak sırala seçeneğinin seçimini kaldırın.
-
İfadeye göre sırala seçeneğini belirleyin ve şuna benzer bir ifade girin:
=mixmatch( Cities, 'Toronto','Boston','Beijing','Stockholm','Zurich')
Cities sütunundaki sıralama düzeni değişir.
Şehirler |
---|
Toronto |
Boston |
Beijing |
Stockholm |
zurich |
Döndürülen sayısal değeri de görüntüleyebilirsiniz.
Şehirler | Cities & ' - ' & mixmatch ( Cities, 'Toronto','Boston', 'Beijing','Stockholm','Zurich') |
---|---|
Toronto | Toronto - 1 |
Boston | Boston - 2 |
Beijing | Beijing - 3 |
Stockholm | Stockholm - 4 |
zurich | zurich - 5 |
Yükleme kodu
Veri alt kümesini yüklemek için mixmatch öğesini kullanabilirsiniz. Örneğin, fonksiyondaki bir ifade için sayısal değer döndürebilirsiniz. Daha sonra sayısal değere göre verileri sınırlayabilirsiniz. Bir eşleşme olmadığında Mixmatch, 0 değerini döndürür. Bu nedenle bu örnekte eşleşmeyen tüm ifadeler 0 değerini döndürür ve WHERE deyimi tarafından veri yüklemesinden hariç tutulur.
Veri yükleme düzenleyicisi'nde Load adlı yeni bir bölüm oluşturun ve sonra aşağıdakileri ekleyin:
Load * Inline [
transaction_id, transaction_date, transaction_amount, transaction_quantity, customer_id, size, color_code
3750, 20180830, 23.56, 2, 2038593, L, Red
3751, 20180907, 556.31, 6, 203521, m, orange
3752, 20180916, 5.75, 1, 5646471, S, blue
3753, 20180922, 125.00, 7, 3036491, l, Black
3754, 20180922, 484.21, 13, 049681, xs, Red
3756, 20180922, 59.18, 2, 2038593, M, Blue
3757, 20180923, 177.42, 21, 203521, XL, Black
];
/*
Create new table called Transaction_Buckets
Create new fields called Customer, and Color code - Black, Blue, blue
Load Transactions table.
Mixmatch returns 1 for 'Black', 2 for 'Blue'.
Also returns 3 for 'blue' because mixmatch is not case sensitive.
Only values that returned numeric value greater than 0
are loaded by WHERE statement into Transactions_Buckets table.
*/
Transaction_Buckets:
Load
customer_id,
customer_id as [Customer],
color_code as [Color Code - Black, Blue, blue]
Resident Transactions
Where mixmatch(color_code,'Black','Blue') > 0;
Sonuçlar
Renk kodu Black, Blue, blue | Customer |
---|---|
Black | 203521 |
Black | 3036491 |
Blue | 2038593 |
blue | 5646471 |