الفرق بين المراجعتين لصفحة: «Kotlin/collections/joinToString»

من موسوعة حسوب
أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: الدالة <code>joinToString()‎</code> في لغة Kotlin}}</noinclude> يخت تجمّع الدالة<code>joinToString()‎</code> K...'
 
طلا ملخص تعديل
 
(4 مراجعات متوسطة بواسطة 3 مستخدمين غير معروضة)
سطر 1: سطر 1:
<noinclude>{{DISPLAYTITLE: الدالة <code>joinToString()‎</code> في لغة Kotlin}}</noinclude>
<noinclude>{{DISPLAYTITLE: الدالة <code>joinToString()‎</code> في Kotlin}}</noinclude>
يخت
تضيف الدالة <code>joinToString()‎</code> بادئة ولاحقة إلى جميع عناصر [[Kotlin/Array|المصفوفة]] أو [[Kotlin/collections|المجموعة]] التي استُدعيت معها (أو جزءٍ منها) بعد فصل عناصرها بفاصلة معينة ثمَّ تضع الناتج في [[Kotlin/String|سلسة نصية]] جديدة تنشئها آنذاك.


تجمّع الدالة<code>joinToString()‎</code> [[Kotlin/String|سلسة نصية]] من عناصر [[Kotlin/Array|المصفوفة]] أو [[Kotlin/collections|المجموعة]] التي استُدعيت عبرها مفصولة بالمعامل المُمرّر  <code>separator</code> وباستخدام البادئة <code>prefix</code> واللاحقة <code>postfix</code> في حال تمريرهما،
إن كانت [[Kotlin/collections|المجموعة]] كبيرة، فيمكن تحديد جزءٍ أولي معين منها فقط لإضافته إلى السلسلة النصية؛ في هذه الحالة، تضاف سلسلة نصية معيَّنة، مثل "..." أو "...إلخ" إلى السلسلة النصية الناتجة للدلالة على وجود جزءٍ مقتطعٍ.
 
إن كانت [[Kotlin/collections|المجموعة]] كبيرة فيمكن تمرير عدد موجب <code>limit</code>، وفي تلك الحالة سيكون عدد العناصر التي تضمّها الدالة <code>joinToString()‎</code> هو <code>limit</code> إضافة إلى [[Kotlin/String|السلسلة النصية]] <code>truncated</code> التي قيمتها الابتدائية <code>"..."</code>.
==البنية العامة==
==البنية العامة==
<syntaxhighlight lang="kotlin">
<syntaxhighlight lang="kotlin">
fun <T, A> Array<out T>.joinTo(
fun <T> Array<out T>.joinToString(
    buffer: A,
     separator: CharSequence = ", ",  
     separator: CharSequence = ", ",  
     prefix: CharSequence = "",  
     prefix: CharSequence = "",  
سطر 15: سطر 12:
     truncated: CharSequence = "...",  
     truncated: CharSequence = "...",  
     transform: (T) -> CharSequence = null
     transform: (T) -> CharSequence = null
): A
): String
fun <A> ByteArray.joinTo(
fun ByteArray.joinToString(
    buffer: A,
     separator: CharSequence = ", ",  
     separator: CharSequence = ", ",  
     prefix: CharSequence = "",  
     prefix: CharSequence = "",  
سطر 24: سطر 20:
     truncated: CharSequence = "...",  
     truncated: CharSequence = "...",  
     transform: (Byte) -> CharSequence = null
     transform: (Byte) -> CharSequence = null
): A
): String
fun <A> ShortArray.joinTo(
fun ShortArray.joinToString(
    buffer: A,
     separator: CharSequence = ", ",  
     separator: CharSequence = ", ",  
     prefix: CharSequence = "",  
     prefix: CharSequence = "",  
سطر 33: سطر 28:
     truncated: CharSequence = "...",  
     truncated: CharSequence = "...",  
     transform: (Short) -> CharSequence = null
     transform: (Short) -> CharSequence = null
): A
): String
fun <A> IntArray.joinTo(
fun IntArray.joinToString(
    buffer: A,
     separator: CharSequence = ", ",  
     separator: CharSequence = ", ",  
     prefix: CharSequence = "",  
     prefix: CharSequence = "",  
سطر 42: سطر 36:
     truncated: CharSequence = "...",  
     truncated: CharSequence = "...",  
     transform: (Int) -> CharSequence = null
     transform: (Int) -> CharSequence = null
): A
): String
fun <A> LongArray.joinTo(
fun LongArray.joinToString(
    buffer: A,
     separator: CharSequence = ", ",  
     separator: CharSequence = ", ",  
     prefix: CharSequence = "",  
     prefix: CharSequence = "",  
سطر 51: سطر 44:
     truncated: CharSequence = "...",  
     truncated: CharSequence = "...",  
     transform: (Long) -> CharSequence = null
     transform: (Long) -> CharSequence = null
): A
): String
fun <A> FloatArray.joinTo(
fun FloatArray.joinToString(
    buffer: A,
     separator: CharSequence = ", ",  
     separator: CharSequence = ", ",  
     prefix: CharSequence = "",  
     prefix: CharSequence = "",  
سطر 60: سطر 52:
     truncated: CharSequence = "...",  
     truncated: CharSequence = "...",  
     transform: (Float) -> CharSequence = null
     transform: (Float) -> CharSequence = null
): A
): String
fun <A> DoubleArray.joinTo(
fun DoubleArray.joinToString(
    buffer: A,
     separator: CharSequence = ", ",  
     separator: CharSequence = ", ",  
     prefix: CharSequence = "",  
     prefix: CharSequence = "",  
سطر 69: سطر 60:
     truncated: CharSequence = "...",  
     truncated: CharSequence = "...",  
     transform: (Double) -> CharSequence = null
     transform: (Double) -> CharSequence = null
): A
): String
fun <A> BooleanArray.joinTo(
fun BooleanArray.joinToString(
    buffer: A,
     separator: CharSequence = ", ",  
     separator: CharSequence = ", ",  
     prefix: CharSequence = "",  
     prefix: CharSequence = "",  
سطر 78: سطر 68:
     truncated: CharSequence = "...",  
     truncated: CharSequence = "...",  
     transform: (Boolean) -> CharSequence = null
     transform: (Boolean) -> CharSequence = null
): A
): String
fun <A> CharArray.joinTo(
fun CharArray.joinToString(
    buffer: A,
     separator: CharSequence = ", ",  
     separator: CharSequence = ", ",  
     prefix: CharSequence = "",  
     prefix: CharSequence = "",  
سطر 87: سطر 76:
     truncated: CharSequence = "...",  
     truncated: CharSequence = "...",  
     transform: (Char) -> CharSequence = null
     transform: (Char) -> CharSequence = null
): A
): String
fun <T, A> Iterable<T>.joinTo(
fun <T> Iterable<T>.joinToString(
    buffer: A,
     separator: CharSequence = ", ",  
     separator: CharSequence = ", ",  
     prefix: CharSequence = "",  
     prefix: CharSequence = "",  
سطر 96: سطر 84:
     truncated: CharSequence = "...",  
     truncated: CharSequence = "...",  
     transform: (T) -> CharSequence = null
     transform: (T) -> CharSequence = null
): A
): String


</syntaxhighlight>
</syntaxhighlight>
==القيم المٌعادة==
[[Kotlin/String|سلسة نصية]] مكونة من عناصر [[Kotlin/Array|المصفوفة]] أو [[Kotlin/collections|المجموعة]] التي استُدعيت عبرها مفصولة بالمعامل المُمرّر  <code>separator</code> وباستخدام البادئة <code>prefix</code> واللاحقة <code>postfix</code> في حال تمريرهما،


إن كانت [[Kotlin/collections|المجموعة]] كبيرة فيمكن تمرير عدد موجب <code>limit</code>، وفي تلك الحالة سيكون عدد العناصر التي تضمّها الدالة <code>joinTo()‎</code> هو <code>limit</code> إضافة إلى [[Kotlin/String|السلسلة النصية]] <code>truncated</code> التي قيمتها الابتدائية <code>"..."</code>.
== المعاملات ==
 
=== <code>separator</code> ===
الفاصل المستعمل في فصل العناصر. القيمة الافتراضية هي: <code>" ,"</code>.
 
=== <code>prefix</code> ===
البادئة المراد إضافتها إلى بداية العناصر. القيمة الافتراضية هي: <code>""</code>.
 
=== <code>postfix</code> ===
اللاحقة المراد إضافتها إلى نهاية العناصر. القيمة الافتراضية هي: <code>""</code>.
 
=== <code>limit</code> ===
عدد صحيح يمثل العدد الأقصى للعناصر المراد تطبيق العملية عليها. القيمة الافتراضية هي: 1-.
 
=== <code>truncated</code> ===
سلسلة نصية تمثل الجزء الذي سيحل مكان الجزء المقتطع من العناصر. القيمة الافتراضية هي: <code>"..."</code>.
 
=== <code>transform</code> ===
دالة تطبق على كل عنصر من عناصر <nowiki/>[[Kotlin/Array|المصفوفة]] أو <nowiki/>[[Kotlin/collections|المجموعة]] المعطاة، إذ يمرر إليها العنصر وتعيد السلسلة النصية المقابلة له.
 
==القيم المعادة==
تُعاد سلسلة نصية تحوي عناصر [[Kotlin/Array|المصفوفة]] أو [[Kotlin/collections|المجموعة]] المعطاة (أو الجزء <code>limit</code> الأولي منها فقط) بعد فصلها بالفاصل <code>separator</code> وإضافة البادئة <code>prefix</code> واللاحقة <code>postfix</code> إليها إن أعطيت هذه المعاملات. عند تحديد المعامل <code>limit</code>، ستضاف السلسلة النصية <code>truncated</code> (قيمتها الافتراضية هي "...") إلى نهاية السلسلة النصية المعادة لتشير إلى وجود جزء مقتطع. 
==أمثلة==
==أمثلة==
===استخدام الدالة <code>()joinToString</code> مع اللوائح: الحالة الأولى===
توضح الشيفرة التالية كيفية إضافة بادئة ولاحقة إلى عناصر قائمةٍ بعد فصلها بفاصل معين:<syntaxhighlight lang="kotlin">
تعرف الشيفرة الآتية  [[Kotlin/String|سلسة نصية]]<nowiki/> باسم <code>sb</code>  باستخدام الدالة <code>()StringBuilder</code>، ثم تُنشئ  [[Kotlin/collections/List|لائحة]] باسم <code>numbers</code> مكونة من ثلاثة أعداد باستخدام الدالة <code>()listOf</code>، ثم تستخدم الدالة <code>()joinToString</code> على <code>numbers</code> بتمرير  <code>sb</code> وبادئة ولاحقة ، ثم تطبع الناتج:<syntaxhighlight lang="kotlin">
fun main(args: Array<String>) {
fun main(args: Array<String>) {
val sb = StringBuilder("An existing string and a list: ")
    val numbers = listOf(1, 2, 3, 4, 5, 6)
val numbers = listOf(1, 2, 3)
    println(numbers.joinToString()) // 1, 2, 3, 4, 5, 6
      
     println(numbers.joinToString(prefix = "[", postfix = "]")) // [1, 2, 3, 4, 5, 6]
println(numbers.joinTo(sb, prefix = "[", postfix = "]").toString()) // An existing string and a list: [1, 2, 3]
    println(numbers.joinToString(prefix = "<", postfix = ">", separator = "•")) // <1•2•3•4•5•6>
}
}
</syntaxhighlight>
</syntaxhighlight>أما الشيفرة التالية، فتوضح كيفية إضافة بادئة ولاحقة إلى أول خمسة عناصر من قائمةٍ بعد فصلها بفاصل معين وإضافة سلسلة نصية معينة تدل على وجود جزء مقتطع:<syntaxhighlight lang="kotlin">
===استخدام الدالة <code>()joinToString</code> مع اللوائح: الحالة الثانية===
تعرف الشيفرة الآتية  [[Kotlin/String|سلسة نصية]] باسم <code>sb</code>  باستخدام الدالة <code>()StringBuilder</code>، ثم تُنشئ  [[Kotlin/collections/List|لائحة]] باسم <code>numbers</code> مكونة من 7أعداد باستخدام الدالة <code>()listOf</code>، ثم تستخدم الدالة <code>()joinToString</code> على <code>numbers</code> بتمرير  <code>sb</code> ومعامل <code>limit</code> ، ثم تطبع الناتج:<nowiki/><syntaxhighlight lang="kotlin">
fun main(args: Array<String>) {
fun main(args: Array<String>) {
val sb = StringBuilder("An existing string and a list: ")
    val chars = charArrayOf('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q')
val numbers = listOf(1, 2, 3, 6 , 8, 9, 5)
     println(chars.joinToString(limit = 5, truncated = "...!") { it.toUpperCase().toString() }) // A, B, C, D, E, ...!
      
println(numbers.joinTo(sb, limit = 5).toString()) // An existing string and a list: 1, 2, 3, 6, 8, ...
}
}
</syntaxhighlight>
</syntaxhighlight>
==انظر أيضًا==
==انظر أيضًا==
<code>[[Kotlin/collections/joinToString|joinToString()]]</code>‎: تنشئ [[Kotlin/String|سلسة نصية]] من عناصر [[Kotlin/Array|المصفوفة]] أو [[Kotlin/collections|المجموعة]] التي استُدعيت عبرها مفصولة بالمعامل المُمرّر  <code>separator</code> وباستخدام البادئة <code>prefix</code> واللاحقة <code>postfix</code> في حال تمريرهما،
* الدالة <code>[[Kotlin/collections/joinTo|joinTo()]]</code>‎: تضيف بادئة ولاحقة إلى جميع عناصر [[Kotlin/Array|المصفوفة]] أو [[Kotlin/collections|المجموعة]] التي استُدعيت معها (أو جزءٍ منها) وتفصلها بفاصلة معينة ثمَّ تضيفها إلى [[Kotlin/String|سلسة نصية]] موجودة مسبقًا.
* الدالة <code>[[Kotlin/collections/getOrElse|getOrElse()‎]]</code>: تجلب عنصرًا ذي فهرس مُحدَّد من <nowiki/>[[Kotlin/Array|المصفوفة]] أو <nowiki/>[[Kotlin/collections|المجموعة]] التي استُدعيت معها أو القيمة المقابلة لمفتاح محدَّد إن استدعيت مع خريطة.
 
==مصادر==
==مصادر==
[https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/join-to.html الدالة joinToString()‎ في التوثيق الرسمي للمكتبة القياسية في لغة Kotlin]
* [https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/join-to-string.html صفحة الدالة joinToString()‎ في التوثيق الرسمي للمكتبة القياسية في لغة Kotlin]
[[تصنيف:Kotlin]]
[[تصنيف:Kotlin]]
[[تصنيف:Kotlin Functions]]
[[تصنيف:Kotlin Function]]
[[تصنيف:Kotlin Collection]]

المراجعة الحالية بتاريخ 09:19، 8 سبتمبر 2018

تضيف الدالة joinToString()‎ بادئة ولاحقة إلى جميع عناصر المصفوفة أو المجموعة التي استُدعيت معها (أو جزءٍ منها) بعد فصل عناصرها بفاصلة معينة ثمَّ تضع الناتج في سلسة نصية جديدة تنشئها آنذاك.

إن كانت المجموعة كبيرة، فيمكن تحديد جزءٍ أولي معين منها فقط لإضافته إلى السلسلة النصية؛ في هذه الحالة، تضاف سلسلة نصية معيَّنة، مثل "..." أو "...إلخ" إلى السلسلة النصية الناتجة للدلالة على وجود جزءٍ مقتطعٍ.

البنية العامة

fun <T> Array<out T>.joinToString(
    separator: CharSequence = ", ", 
    prefix: CharSequence = "", 
    postfix: CharSequence = "", 
    limit: Int = -1, 
    truncated: CharSequence = "...", 
    transform: (T) -> CharSequence = null
): String 
fun ByteArray.joinToString(
    separator: CharSequence = ", ", 
    prefix: CharSequence = "", 
    postfix: CharSequence = "", 
    limit: Int = -1, 
    truncated: CharSequence = "...", 
    transform: (Byte) -> CharSequence = null
): String 
fun ShortArray.joinToString(
    separator: CharSequence = ", ", 
    prefix: CharSequence = "", 
    postfix: CharSequence = "", 
    limit: Int = -1, 
    truncated: CharSequence = "...", 
    transform: (Short) -> CharSequence = null
): String 
fun IntArray.joinToString(
    separator: CharSequence = ", ", 
    prefix: CharSequence = "", 
    postfix: CharSequence = "", 
    limit: Int = -1, 
    truncated: CharSequence = "...", 
    transform: (Int) -> CharSequence = null
): String 
fun LongArray.joinToString(
    separator: CharSequence = ", ", 
    prefix: CharSequence = "", 
    postfix: CharSequence = "", 
    limit: Int = -1, 
    truncated: CharSequence = "...", 
    transform: (Long) -> CharSequence = null
): String 
fun FloatArray.joinToString(
    separator: CharSequence = ", ", 
    prefix: CharSequence = "", 
    postfix: CharSequence = "", 
    limit: Int = -1, 
    truncated: CharSequence = "...", 
    transform: (Float) -> CharSequence = null
): String 
fun DoubleArray.joinToString(
    separator: CharSequence = ", ", 
    prefix: CharSequence = "", 
    postfix: CharSequence = "", 
    limit: Int = -1, 
    truncated: CharSequence = "...", 
    transform: (Double) -> CharSequence = null
): String 
fun BooleanArray.joinToString(
    separator: CharSequence = ", ", 
    prefix: CharSequence = "", 
    postfix: CharSequence = "", 
    limit: Int = -1, 
    truncated: CharSequence = "...", 
    transform: (Boolean) -> CharSequence = null
): String 
fun CharArray.joinToString(
    separator: CharSequence = ", ", 
    prefix: CharSequence = "", 
    postfix: CharSequence = "", 
    limit: Int = -1, 
    truncated: CharSequence = "...", 
    transform: (Char) -> CharSequence = null
): String 
fun <T> Iterable<T>.joinToString(
    separator: CharSequence = ", ", 
    prefix: CharSequence = "", 
    postfix: CharSequence = "", 
    limit: Int = -1, 
    truncated: CharSequence = "...", 
    transform: (T) -> CharSequence = null
): String

المعاملات

separator

الفاصل المستعمل في فصل العناصر. القيمة الافتراضية هي: " ,".

prefix

البادئة المراد إضافتها إلى بداية العناصر. القيمة الافتراضية هي: "".

postfix

اللاحقة المراد إضافتها إلى نهاية العناصر. القيمة الافتراضية هي: "".

limit

عدد صحيح يمثل العدد الأقصى للعناصر المراد تطبيق العملية عليها. القيمة الافتراضية هي: 1-.

truncated

سلسلة نصية تمثل الجزء الذي سيحل مكان الجزء المقتطع من العناصر. القيمة الافتراضية هي: "...".

transform

دالة تطبق على كل عنصر من عناصر المصفوفة أو المجموعة المعطاة، إذ يمرر إليها العنصر وتعيد السلسلة النصية المقابلة له.

القيم المعادة

تُعاد سلسلة نصية تحوي عناصر المصفوفة أو المجموعة المعطاة (أو الجزء limit الأولي منها فقط) بعد فصلها بالفاصل separator وإضافة البادئة prefix واللاحقة postfix إليها إن أعطيت هذه المعاملات. عند تحديد المعامل limit، ستضاف السلسلة النصية truncated (قيمتها الافتراضية هي "...") إلى نهاية السلسلة النصية المعادة لتشير إلى وجود جزء مقتطع. 

أمثلة

توضح الشيفرة التالية كيفية إضافة بادئة ولاحقة إلى عناصر قائمةٍ بعد فصلها بفاصل معين:

fun main(args: Array<String>) {
    val numbers = listOf(1, 2, 3, 4, 5, 6)
    println(numbers.joinToString()) // 1, 2, 3, 4, 5, 6
    println(numbers.joinToString(prefix = "[", postfix = "]")) // [1, 2, 3, 4, 5, 6]
    println(numbers.joinToString(prefix = "<", postfix = ">", separator = "•")) // <1•2•3•4•5•6>
}

أما الشيفرة التالية، فتوضح كيفية إضافة بادئة ولاحقة إلى أول خمسة عناصر من قائمةٍ بعد فصلها بفاصل معين وإضافة سلسلة نصية معينة تدل على وجود جزء مقتطع:

fun main(args: Array<String>) {
    val chars = charArrayOf('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q')
    println(chars.joinToString(limit = 5, truncated = "...!") { it.toUpperCase().toString() }) // A, B, C, D, E, ...!
}

انظر أيضًا

  • الدالة joinTo()‎: تضيف بادئة ولاحقة إلى جميع عناصر المصفوفة أو المجموعة التي استُدعيت معها (أو جزءٍ منها) وتفصلها بفاصلة معينة ثمَّ تضيفها إلى سلسة نصية موجودة مسبقًا.
  • الدالة getOrElse()‎: تجلب عنصرًا ذي فهرس مُحدَّد من المصفوفة أو المجموعة التي استُدعيت معها أو القيمة المقابلة لمفتاح محدَّد إن استدعيت مع خريطة.

مصادر