الفرق بين المراجعتين لصفحة: «Python/bytes/rfind»

من موسوعة حسوب
< Python‏ | bytes
سطر 5: سطر 5:


<syntaxhighlight lang="python3">
<syntaxhighlight lang="python3">
b.rfind()
str.rfind(sub[, start[, end]])</syntaxhighlight>
</syntaxhighlight>


== المعاملات ==
== المعاملات ==

مراجعة 07:34، 9 يونيو 2018

يعيد التابع أعلى قيمة للفهرس في التسلسل الأصلي حيث تجد فيه التسلسل الفرعي.

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

str.rfind(sub[, start[, end]])

المعاملات

sub

التسلسل الفرعي المراد معرفة موقعه.

يمكن أن يكون هذا المعامل أي كائن شبيه بالبايتات (bytes-like object) أو عددًا صحيحًا يبدأ من 0 وينتهي بالعدد 255.

start

الموقع الذي يبدأ منه التابع عملية البحث ضمن التسلسل الأصلي.

end

الموقع الذي ينهي فيه التابع عملية البحث ضمن التسلسل الأصلي.

يسلك هذان المعاملان الاختياريان نفس السلوك المتّبع في عملية اقتطاع السلاسل النصية slicing.

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

يعيد التابع أعلى قيمة للفهرس في التسلسل الأصلي حيث تجد فيه التسلسل الفرعي، بحيث يكون التسلسل الفرعي ضمن النطاق s[start:end]‎‎.

يعيد التابع القيمة ‎-1‎ إن لم يعثر على التسلسل الفرعي.

أمثلة

يبين المثال التالي النتائج المعادة من استخدام التابع:

>>> byte = b'Python, Python, Python'
>>> byte.rfind(b'Py')
16
>>> byte.rfind(b'Py', 0 , 10)
8
>>> byte.rfind(b'C++')
-1
>>> byte.rfind(44)
14
>>> byte.rfind(12)
-1

انظر أيضًا

  • البايتات في بايثون.
  • التابع bytes.find()‎: إعادة أدنى قيمة للفهرس والذي يكون التسلسل الفرعي موجودًا في ضمن البيانات الثنائية.
  • التابع bytes.index()‎: يؤدي هذا التابع نفس وظيفة التابع bytes.find()‎ ولكنّه يطلق الخطأ ValueError إن لم يعثر على التسلسل الفرعي.
  • التابع bytes.rindex()‎: يشبه التابع bytes.rfind()‎ في أنّه يحدّد أعلى قيمة للفهرس تجد فيه التسلسل الفرعي ضمن التسلسل الأصلي، ويختلف عنه في أنّه يطلق الخطأ ValueError إن لم يعثر على التسلسل الفرعي.

مصادر