الفرق بين المراجعتين ل"Kotlin/kotlin.text/replace"

من موسوعة حسوب
اذهب إلى التنقل اذهب إلى البحث
سطر 25: سطر 25:
 
): String
 
): String
 
</syntaxhighlight>في حال استدعاء  الدالة <code>replace()‎</code> عبر [[Kotlin/CharSequence/index|سلسلة حروف]] مع تمرير [[Kotlin/kotlin.text/Regex/index|تعبير نمطي]] <code>regex</code> ودالة  <code>transform</code> كوسيطين فستعيد  [[Kotlin/String|سلسلة نصية]] جديدة مع تعويض كل المُطابقات  [[Kotlin/kotlin.text/Regex/index|للتعبير النمطي]] <code>regex</code> بناتج تطبيق الدالة  <code>transform</code> والتي تأخذ كائنا من النوع <code>[[Kotlin/kotlin.text/MatchResult/index|MatchResult]]</code> وتعيد  [[Kotlin/String|سلسلة نصية]] لاستخدامها في عملية التعويض.
 
</syntaxhighlight>في حال استدعاء  الدالة <code>replace()‎</code> عبر [[Kotlin/CharSequence/index|سلسلة حروف]] مع تمرير [[Kotlin/kotlin.text/Regex/index|تعبير نمطي]] <code>regex</code> ودالة  <code>transform</code> كوسيطين فستعيد  [[Kotlin/String|سلسلة نصية]] جديدة مع تعويض كل المُطابقات  [[Kotlin/kotlin.text/Regex/index|للتعبير النمطي]] <code>regex</code> بناتج تطبيق الدالة  <code>transform</code> والتي تأخذ كائنا من النوع <code>[[Kotlin/kotlin.text/MatchResult/index|MatchResult]]</code> وتعيد  [[Kotlin/String|سلسلة نصية]] لاستخدامها في عملية التعويض.
 +
 +
يُلاحَظ وجود الكلمة المفتاحية <code>inline</code> للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع <nowiki/>[[Kotlin/inline functions|توثيق الدوال المباشرة (inline functions)]].
  
 
==القيم المعادة==
 
==القيم المعادة==

مراجعة 10:50، 12 يوليو 2018

يختلف سلوك الدالة replace()‎ بحسب أنواع الوسائط المُمررة (انظر فقرة البنيةالعامة).

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

actual fun String.replace(
    oldChar: Char, 
    newChar: Char, 
    ignoreCase: Boolean = false
): String

في حال استدعاء الدالة replace()‎ عبر سلسلة نصية مع تمرير حرفينoldChar و newChar كوسيطين فستعيد سلسلة نصية جديدة مع تعويض الحرف oldChar بالحرف newChar.

actual fun String.replace(
    oldValue: String, 
    newValue: String, 
    ignoreCase: Boolean = false
): String

في حال استدعاء الدالة replace()‎ عبر سلسلة نصية مع تمرير سلسلتين نصيتين oldValue و newValue كوسيطين فستعيد سلسلة نصية جديدة مع تعويض oldValue بـ newValue.

inline fun CharSequence.replace(
    regex: Regex, 
    replacement: String
): String

في حال استدعاء الدالة replace()‎ عبر سلسلة حروف مع تمرير تعبير نمطي regex وسلسلة نصية replacement كوسيطين فستعيد سلسلة نصية جديدة مع تعويض كل المُطابقات للتعبير النمطي regex بالسلسلة النصية replacement.

inline fun CharSequence.replace(
    regex: Regex, 
    noinline transform: (MatchResult) -> CharSequence
): String

في حال استدعاء الدالة replace()‎ عبر سلسلة حروف مع تمرير تعبير نمطي regex ودالة transform كوسيطين فستعيد سلسلة نصية جديدة مع تعويض كل المُطابقات للتعبير النمطي regex بناتج تطبيق الدالة transform والتي تأخذ كائنا من النوع MatchResult وتعيد سلسلة نصية لاستخدامها في عملية التعويض.

يُلاحَظ وجود الكلمة المفتاحية inline للدلالة على أن هذه الدالة مباشرة، وللمزيد من التفاصيل راجع توثيق الدوال المباشرة (inline functions).

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

سلسلة نصية.

أمثلة

استخدام الدالة ()replace مع سلسلة نصية

تعرِّف الشيفرة الآتية سلسلة نصية باسم str، ثمَّ تستدعي الدالة ()replace عبرها مع تجريب عدة أنواع من الوسائط، ثمَّ تطبع الناتج:

fun main(args: Array<String>) {
val str = "abc12rad234com" 
    
println( str.replace ('a','X') ) // Xbc12rXd234com
println( str.replace ("rad","X") ) // abc12X234com
println( str.replace (Regex("""-?\d+(\.\d+)?"""), "X") ) // abcXradXcom
println( str.replace (Regex("""-?\d+(\.\d+)?""")) {it.value} ) // abc12rad234com
}

انظر أيضًا

مصادر