اذهب إلى المحتوى

السؤال

نشر

هل هنالك طريقة معينة للحصول على العنصر الشهير (الأكثر تكرارا) في سلسلة نصية معينة في بايثون؟ أريد دالة تعمل بهذه الطريقة:

>>> most_common(['duck', 'duck', 'goose'])
'duck'
>>> most_common(['goose', 'duck', 'duck', 'goose'])
'goose'

Recommended Posts

  • 0
نشر

يوجد العديد من الطرق لفعل هذا في بايثون، بعضها طويلا ومعقد للغاية وبعضها قصيرا، فيمكنك على سبيل المثال إنشاء دالة بسطر واحد تحتوي على دوال مدمجة متنوعة مثل max وset كما يظهر في هذه الدالة:

def most_common(lst):
    return max(set(lst), key=lst.count)

وإذا كنت تستخدم الإصدار 2.7 من بايثون فيمكنك في هذه الحالة استخدام دالة Counter من مكتبة collections لإنشاء دالة قصيرة جدا وسريعة جدا (أسرع بكثير من المثال السابق) كما في المثال التالي:

from collections import Counter

def Most_Common(lst):
    data = Counter(lst)
    return data.most_common(1)[0][0

انضم إلى النقاش

يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.

زائر
أجب على هذا السؤال...

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   جرى استعادة المحتوى السابق..   امسح المحرر

×   You cannot paste images directly. Upload or insert images from URL.

  • إعلانات

  • تابعنا على



×
×
  • أضف...