كيف تنتظر حتى يتم تحميل صفحة بالسيلينيوم

How Wait Page Load With Selenium



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

سبب حدوث ذلك هو أنه يجب على برنامج تشغيل الويب السيلينيوم تنزيل صفحة الويب والانتهاء من عرض الصفحة قبل أن تتمكن من القيام بأي شيء عليها. في الماضي ، كان خادم الويب ينشئ محتوى موقع ويب ، وقام المتصفح بتنزيله وعرضه. في هذه الأيام ، لدينا العديد من تطبيقات الويب أحادية الصفحة التي تعمل بشكل مختلف قليلاً. في تطبيقات الويب ذات الصفحة الواحدة (SPAs) ، يقدم خادم الويب رموز الواجهة الأمامية فقط. بمجرد تقديم كود الواجهة الأمامية على المتصفح ، يستخدم كود الواجهة AJAX لطلب بيانات API إلى خادم الويب. بمجرد أن تتلقى الواجهة الأمامية بيانات API ، فإنها تعرضها على المتصفح. لذلك ، على الرغم من انتهاء المتصفح من تنزيل صفحة الويب وعرضها ، إلا أن صفحة الويب لا تزال غير جاهزة. يجب عليك الانتظار حتى تتلقى بيانات API وتقديمها أيضًا. لذا ، فإن حل هذه المشكلة هو انتظار توفر البيانات قبل أن نفعل أي شيء مع السيلينيوم.







في السيلينيوم ، هناك نوعان من فترات الانتظار:
1) الانتظار الضمني
2) الانتظار الصريح



1) الانتظار الضمني: هذا هو أسهل تطبيق. يخبر الانتظار الضمني محرك الويب Selenium بالانتظار لعدة ثوانٍ حتى يكون DOM (نموذج كائن المستند) جاهزًا (تكون صفحة الويب جاهزة).



2) الانتظار الصريح: هذا معقد بعض الشيء من الانتظار الضمني. في الانتظار الصريح ، تخبر برنامج تشغيل الويب السيلينيوم بما ينتظره. ينتظر السيلينيوم أن يتحقق هذا الشرط المحدد. بمجرد اكتماله ، سيكون برنامج تشغيل الويب السيلينيوم جاهزًا لأخذ أوامر أخرى. عادةً ما يكون وقت الانتظار الصريح متغيرًا. يعتمد ذلك على مدى سرعة تلبية الشروط. في أسوأ السيناريوهات ، سينتظر الانتظار الصريح ما دام الانتظار الضمني.





في هذه المقالة ، سأوضح لك كيفية الانتظار (ضمنيًا وصريحًا) حتى يتم تحميل صفحة بالسيلينيوم. لذلك دعونا نبدأ.

المتطلبات الأساسية:

لتجربة أوامر وأمثلة هذه المقالة ، يجب أن يكون لديك ،



1) توزيعة Linux (يفضل Ubuntu) مثبتة على جهاز الكمبيوتر الخاص بك.
2) Python 3 مثبت على جهاز الكمبيوتر الخاص بك.
3) تثبيت PIP 3 على جهاز الكمبيوتر الخاص بك.
4) بايثون فيرتالينف حزمة مثبتة على جهاز الكمبيوتر الخاص بك.
5) Mozilla Firefox أو متصفحات الويب Google Chrome مثبتة على جهاز الكمبيوتر الخاص بك.
6) يجب معرفة كيفية تثبيت Firefox Gecko Driver أو Chrome Web Driver.

لاستيفاء المتطلبات 4 و 5 و 6 ، اقرأ مقالتي مقدمة عن السيلينيوم مع بايثون 3 في Linuxhint.com.

يمكنك العثور على العديد من المقالات حول الموضوعات الأخرى على LinuxHint.com . تأكد من التحقق منها إذا كنت بحاجة إلى أي مساعدة.

إعداد دليل المشروع:

للحفاظ على كل شيء منظمًا ، قم بإنشاء دليل مشروع جديد السيلينيوم-انتظر / على النحو التالي:

$مكدير -pvالسيلينيوم انتظر/السائقين

انتقل إلى ملف السيلينيوم-انتظر / دليل المشروع على النحو التالي:

$قرص مضغوطالسيلينيوم انتظر/

قم بإنشاء بيئة افتراضية Python في دليل المشروع على النحو التالي:

$virtualenv .venv

تفعيل البيئة الافتراضية كالتالي:

$مصدر.venv/صباحا/تفعيل

قم بتثبيت السيلينيوم باستخدام PIP3 على النحو التالي:

$ pip3 قم بتثبيت السيلينيوم

قم بتنزيل وتثبيت جميع برامج تشغيل الويب المطلوبة في ملف السائقين/ دليل المشروع. لقد شرحت عملية تنزيل برامج تشغيل الويب وتثبيتها في مقالتي مقدمة عن السيلينيوم مع بايثون 3 . إذا كنت بحاجة إلى أي مساعدة ، فابحث عن LinuxHint.com لتلك المقالة.

سأستخدم متصفح الويب Google Chrome في العرض التوضيحي في هذه المقالة. لذلك ، سأستخدم ملف chromedriver ثنائي من السائقين/ الدليل.

لتجربة الانتظار الضمني ، قم بإنشاء نص برمجي جديد للبايثون ex01.py في دليل مشروعك واكتب سطور الرموز التالية في هذا الملف.

من عندالسيلينيوميستوردwebdriver
من عندالسيلينيوم.webdriver.مشترك.مفاتيح يستوردمفاتيح
والخيارات=webdriver.خيارات Chrome()
والخيارات.مقطوعة الرأس = حقيقي
المتصفح=webdriver.كروم(قابل للتنفيذ='./drivers/chromedriver'ووالخيارات=والخيارات)
المتصفح.انتظر ضمنيًا(10)
المتصفح.احصل على('https://www.unixtimestamp.com/')
الطابع الزمني=المتصفح.find_element_by_xpath('//h3[@][1]')
مطبعة(الطابع الزمني الحالي:٪ s٪(الطابع الزمني.نص.الانقسام(')[0]))
المتصفح.أغلق()

بمجرد الانتهاء ، احفظ ملف ex01.py نص بايثون.

يستورد الخط 1 و 2 جميع مكونات السيلينيوم المطلوبة.

ينشئ السطر 4 كائن خيارات Chrome.

يتيح السطر 5 وضع مقطوعة الرأس لبرنامج تشغيل الويب Chrome.

ينشئ السطر 7 كائن متصفح Chrome باستخدام ملف chromedriver ثنائي من السائقين/ الدليل.

يستخدم الخط 8 لإخبار السيلينيوم بالانتظار ضمنيًا لمدة 10 ثوانٍ باستخدام انتظر ضمنيًا () طريقة المتصفح.

يقوم Line 10 بتحميل www.unixtimestamp.com في المتصفح.

يجد السطر 12 عنصر الطابع الزمني باستخدام محدد XPath // h3 [@ class = ’text-danger’] [1] ويخزنها في الطابع الزمني عامل.

حصلت على محدد XPath من Chrome Developer Tool. كما ترى ، الطابع الزمني موجود في الأول h3 عنصر مع اسم الفئة خطر النص . يوجد 2 h3 العناصر مع الفصل خطر النص .

يقوم السطر 13 بطباعة الطابع الزمني فقط من العنصر الذي حددته باستخدام محدد XPath وتخزينه في ملف الطابع الزمني عامل.

السطر 14 يغلق المتصفح.

بمجرد الانتهاء ، قم بتشغيل نص بايثون ex01.py على النحو التالي:

$ python3 ex01.السنة التحضيرية

كما ترى ، يتم استخراج الطابع الزمني الحالي من unixtimestamp.com وطباعته على وحدة التحكم.

العمل مع الانتظار الصريح:

لتجربة الانتظار الصريح ، قم بإنشاء نص برمجي جديد من Python ex02.py في دليل مشروعك واكتب سطور الرموز التالية في هذا الملف.

من عندالسيلينيوميستوردwebdriver
من عندالسيلينيوم.webdriver.مشترك.مفاتيح يستوردمفاتيح
من عندالسيلينيوم.webdriver.مشترك.بواسطة يستوردبواسطة
من عندالسيلينيوم.webdriver.الدعم.بصلة يستوردWebDriverWait
من عندالسيلينيوم.webdriver.الدعم يستوردالشروط_المتوقعة
والخيارات=webdriver.خيارات Chrome()
والخيارات.مقطوعة الرأس = حقيقي
المتصفح=webdriver.كروم(قابل للتنفيذ='./drivers/chromedriver'ووالخيارات=والخيارات)
المتصفح.احصل على('https://www.unixtimestamp.com/')
محاولة:
الطابع الزمني=WebDriverWait(المتصفحو 10).حتى(
الشروط_المتوقعة.حضور_من_العنصر_الموقع((بواسطة.XPATHو '
//h3[@][1]'
))
)
مطبعة(الطابع الزمني الحالي:٪ s٪(الطابع الزمني.نص.الانقسام(')[0]))
أخيرا:
المتصفح.أغلق()

بمجرد الانتهاء ، احفظ ملف ex02.py نص بايثون.

يستورد السطر 1-5 جميع المكونات المطلوبة من مكتبة السيلينيوم.

ينشئ السطر 7 كائن خيارات Chrome.

يتيح السطر 8 وضع مقطوعة الرأس لبرنامج تشغيل الويب Chrome.

ينشئ Line 10 كائن متصفح Chrome باستخدام امتداد chromedriver ثنائي من السائقين/ الدليل.

يقوم Line 12 بتحميل www.unixtimestamp.com في المتصفح.

يتم تنفيذ الانتظار الصريح في مجموعة المحاولة النهائية (من السطر 14-20)

يستخدم الخط 15-17 WebDriverWait () موضوع. الحجة الأولى من WebDriverWait () هو كائن المتصفح ، والوسيطة الثانية هي الحد الأقصى للوقت المسموح به (سيناريو أسوأ الحالات) لاستيفاء الشرط ، وهو 10 ثوانٍ في هذه الحالة.

في ال حتى() منع، المتوقعة_الظروف. التواجد_من_العنصر_الموقع () يتم استخدام الطريقة للتأكد من وجود العنصر قبل محاولة تحديد العنصر. هنا، By.XPATH يستخدم لمعرفة الحضور_من_العنصر_الموقع () الطريقة التي استخدمناها في محدد XPath لتحديد العنصر. محدد XPath هو // h3 [@ class = ’text-danger’] [1] .

بمجرد العثور على العنصر ، يتم تخزينه في ملف الطابع الزمني عامل.

يطبع السطر 18 الطابع الزمني فقط من العنصر المحدد.

أخيرًا ، السطر 19-20 يغلق المتصفح.

بمجرد الانتهاء ، قم بتشغيل ex02.py نص Python على النحو التالي:

$ python3 ex02.السنة التحضيرية

كما ترى ، تتم طباعة الطابع الزمني الحالي من unixtimestamp.com على وحدة التحكم.

اختيار العناصر في الانتظار الصريح:

في القسم السابق ، لقد استخدمت By.XPATH لاختيار العنصر باستخدام محدد XPath. يمكنك أيضًا تحديد العناصر باستخدام المعرف ، واسم العلامة ، واسم فئة CSS ، ومحدد CSS ، وما إلى ذلك.

طرق الاختيار المدعومة موضحة أدناه:

By.XPATH - يختار العنصر / العناصر باستخدام محدد XPath.

بواسطة CLASS_NAME - يختار عنصر / عناصر باستخدام اسم فئة CSS.

من خلال CSS_SELECTOR - يختار العنصر / العناصر باستخدام محدد CSS.

بواسطة معرف - يختار العنصر عن طريق المعرف

بالاسم - يختار العنصر / العناصر بالاسم.

بواسطة TAG_NAME - يختار العنصر / العناصر بواسطة اسم علامة HTML.

بواسطة LINK_TEXT - يختار العنصر / العناصر عن طريق نص ارتباط إلى (مرساة) علامة HTML.

بقلم: PARTIAL_LINK_TEXT - يختار العنصر / العناصر بنص الارتباط الجزئي لـ إلى (مرساة) علامة HTML.

لمزيد من المعلومات حول هذه ، قم بزيارة صفحة وثائق Python Selenium API .

الشروط المتوقعة في فترات الانتظار الصريحة:

في مثال الانتظار الصريح السابق ، استخدمت ملف الحضور_من_العنصر_الموقع () طريقة الشروط_المتوقعة كشرط انتظار صريح للتأكد من وجود العنصر الذي كنت أبحث عنه قبل تحديده.

هناك المزيد الشروط_المتوقعة يمكنك استخدامها كشرط انتظار صريح. البعض منهم:

title_is (العنوان) - يتحقق ما إذا كان عنوان الصفحة لقب .

العنوان_ يحتوي على (العنوان الجزئي) - يتحقق ما إذا كان عنوان الصفحة يحتوي على جزء من العنوان العنوان الجزئي .

visibility_of (عنصر) - يتحقق ما إذا كان عنصر يكون مرئيًا في الصفحة حيث يكون عرض العنصر وارتفاعه أكبر من 0.

visibility_of_element_located (محدد) -

Location_of_element_located (محدد) - تأكد من أن العنصر الموجود (بواسطة ملف محدد ) موجود في الصفحة. ال محدد عبارة عن مجموعة من (بواسطة ، محدد) ، كما أوضحت في مثال الانتظار الصريح.

الحضور_من_كل_العنصر_الموقع () - يتأكد من أن كل العناصر المطابقة لـ محدد موجود على الصفحة. ال محدد هو (بواسطة المحدد) tuple.

text_to_be_present_in_element (محدد ، نص) - يتحقق ما إذا كان ملف نص موجود في العنصر الموجود بواسطة محدد . ال محدد هو (بواسطة المحدد) tuple.

element_to_be_clickable (محدد) - للتحقق مما إذا كان العنصر الموجود بواسطة ملف محدد مرئي وقابل للنقر. ال محدد هو (بواسطة المحدد) tuple.

element_to_be_selected (محدد) - للتحقق مما إذا كان العنصر الموجود بواسطة ملف محدد تم الإختيار. ال محدد هو (بواسطة المحدد) tuple.

Alert_is_present () - توقع وجود حوار تنبيه على الصفحة.

هناك أكثر من ذلك بكثير الشروط_المتوقعة متاح لك للاستخدام. لمزيد من المعلومات حول هذه ، قم بزيارة صفحة وثائق Python Selenium API .

استنتاج:

لقد ناقشت في هذه المقالة فترات انتظار السيلينيوم الضمنية والصريحة. لقد أوضحت لك أيضًا كيفية العمل مع انتظار ضمني وصريح. يجب أن تحاول دائمًا استخدام الانتظار الصريح في مشاريع السيلينيوم الخاصة بك حيث سيحاول السيلينيوم تقليل وقت الانتظار قدر الإمكان. بهذه الطريقة ، لن تضطر إلى الانتظار لعدد محدد من الثواني في كل مرة تقوم فيها بتشغيل مشاريع السيلينيوم الخاصة بك. يجب أن يوفر الانتظار الصريح الكثير من الثواني.

لمزيد من المعلومات حول ينتظر السيلينيوم ، قم بزيارة تنتظر مكتبة Selenium Python الرسمية صفحة التوثيق .