पायथन वेब स्क्रैपिंग - डेटा एक्सट्रैक्शन

एक वेब पेज का विश्लेषण करने का मतलब है कि इसके संसेचन को समझना। अब, सवाल उठता है कि वेब स्क्रैपिंग के लिए क्यों महत्वपूर्ण है? इस अध्याय में, हम इसे विस्तार से समझते हैं।

वेब पेज विश्लेषण

वेब पेज विश्लेषण महत्वपूर्ण है क्योंकि विश्लेषण किए बिना हम यह नहीं जान पा रहे हैं कि निष्कर्षण के बाद हम उस वेब पेज से किस रूप में (संरचित या असंरचित) डेटा प्राप्त करने जा रहे हैं। हम निम्नलिखित तरीकों से वेब पेज विश्लेषण कर सकते हैं -

पृष्ठ स्रोत देखना

यह समझने का एक तरीका है कि किसी वेब पेज को उसके स्रोत कोड की जांच करके कैसे संरचित किया जाता है। इसे लागू करने के लिए, हमें पेज पर राइट क्लिक करना होगा और फिर सेलेक्ट करना होगाView page sourceविकल्प। फिर, हम HTML के रूप में उस वेब पेज से अपनी रुचि का डेटा प्राप्त करेंगे। लेकिन मुख्य चिंता व्हाट्सएप और फॉर्मेटिंग के बारे में है जिसे प्रारूपित करना हमारे लिए मुश्किल है।

निरीक्षण तत्व विकल्प पर क्लिक करके पृष्ठ स्रोत का निरीक्षण

यह वेब पेज का विश्लेषण करने का एक और तरीका है। लेकिन अंतर यह है कि यह वेब पेज के स्रोत कोड में स्वरूपण और व्हाट्सएप के मुद्दे को हल करेगा। आप इसे राइट क्लिक करके चुन सकते हैं और फिर चुन सकते हैंInspect या Inspect elementमेनू से विकल्प। यह उस वेब पेज के विशेष क्षेत्र या तत्व के बारे में जानकारी प्रदान करेगा।

वेब पेज से डेटा निकालने के विभिन्न तरीके

वेब पेज से डेटा निकालने के लिए निम्नलिखित विधियों का उपयोग किया जाता है -

नियमित अभिव्यक्ति

वे पायथन में एम्बेडेड विशेषीकृत प्रोग्रामिंग भाषा हैं। हम इसके माध्यम से उपयोग कर सकते हैंreअजगर का मॉड्यूल। इसे RE या regexes या regex पैटर्न भी कहा जाता है। नियमित अभिव्यक्तियों की मदद से, हम उन आंकड़ों के संभावित सेट के लिए कुछ नियम निर्दिष्ट कर सकते हैं, जिन्हें हम डेटा से मेल खाना चाहते हैं।

यदि आप सामान्य रूप से नियमित अभिव्यक्ति के बारे में अधिक जानना चाहते हैं, तो लिंक पर जाएं https://www.tutorialspoint.com/automata_theory/regular_expressions.htmऔर यदि आप पायथन में पुनः मॉड्यूल या नियमित अभिव्यक्ति के बारे में अधिक जानना चाहते हैं, तो आप https://www.tutorialspoint.com/python/python_reg_expressions.htm लिंक का अनुसरण कर सकते हैं ।

उदाहरण

निम्नलिखित उदाहरण में, हम भारत के बारे में डेटा को परिमार्जन करने जा रहे हैं http://example.webscraping.com नियमित अभिव्यक्ति की मदद से <td> की सामग्री से मेल खाने के बाद।

import re
import urllib.request
response =
   urllib.request.urlopen('http://example.webscraping.com/places/default/view/India-102')
html = response.read()
text = html.decode()
re.findall('<td class="w2p_fw">(.*?)</td>',text)

उत्पादन

इसी आउटपुट को यहां दिखाया जाएगा -

[
   '<img src="/places/static/images/flags/in.png" />',
   '3,287,590 square kilometres',
   '1,173,108,018',
   'IN',
   'India',
   'New Delhi',
   '<a href="/places/default/continent/AS">AS</a>',
   '.in',
   'INR',
   'Rupee',
   '91',
   '######',
   '^(\\d{6})$',
   'enIN,hi,bn,te,mr,ta,ur,gu,kn,ml,or,pa,as,bh,sat,ks,ne,sd,kok,doi,mni,sit,sa,fr,lus,inc',
   '<div>
      <a href="/places/default/iso/CN">CN </a>
      <a href="/places/default/iso/NP">NP </a>
      <a href="/places/default/iso/MM">MM </a>
      <a href="/places/default/iso/BT">BT </a>
      <a href="/places/default/iso/PK">PK </a>
      <a href="/places/default/iso/BD">BD </a>
   </div>'
]

निरीक्षण करें कि उपरोक्त आउटपुट में आप नियमित अभिव्यक्ति का उपयोग करके देश भारत के बारे में विवरण देख सकते हैं।

सुंदर सूप

मान लें कि हम सभी हाइपरलिंक को एक वेब पेज से इकट्ठा करना चाहते हैं, तो हम ब्यूटीसॉरप नामक एक पार्सर का उपयोग कर सकते हैं जिसे अधिक विवरण में जाना जा सकता है https://www.crummy.com/software/BeautifulSoup/bs4/doc/.सरल शब्दों में, ब्यूटीफुल HTML और XML फ़ाइलों से डेटा खींचने के लिए पायथन लाइब्रेरी है। इसका उपयोग अनुरोधों के साथ किया जा सकता है, क्योंकि इसमें एक सूप ऑब्जेक्ट बनाने के लिए एक इनपुट (डॉक्यूमेंट या यूआरएल) की आवश्यकता होती है, जो अपने आप में एक वेब पेज नहीं ला सकता है। वेब पेज और हाइपरलिंक के शीर्षक को इकट्ठा करने के लिए आप निम्नलिखित पायथन लिपि का उपयोग कर सकते हैं।

सुंदर सूप स्थापित करना

का उपयोग करते हुए pip कमांड, हम स्थापित कर सकते हैं beautifulsoup या तो हमारे आभासी वातावरण में या वैश्विक स्थापना में।

(base) D:\ProgramData>pip install bs4
Collecting bs4
   Downloading
https://files.pythonhosted.org/packages/10/ed/7e8b97591f6f456174139ec089c769f89
a94a1a4025fe967691de971f314/bs4-0.0.1.tar.gz
Requirement already satisfied: beautifulsoup4 in d:\programdata\lib\sitepackages
(from bs4) (4.6.0)
Building wheels for collected packages: bs4
   Running setup.py bdist_wheel for bs4 ... done
   Stored in directory:
C:\Users\gaurav\AppData\Local\pip\Cache\wheels\a0\b0\b2\4f80b9456b87abedbc0bf2d
52235414c3467d8889be38dd472
Successfully built bs4
Installing collected packages: bs4
Successfully installed bs4-0.0.1

उदाहरण

ध्यान दें कि इस उदाहरण में, हम उपरोक्त उदाहरण को अनुरोध के साथ लागू कर रहे हैं। हम प्रयोग कर रहे हैंr.text एक सूप ऑब्जेक्ट बनाने के लिए जिसका उपयोग वेबपेज के शीर्षक जैसे विवरण लाने के लिए किया जाएगा।

सबसे पहले, हमें आवश्यक पायथन मॉड्यूल आयात करने की आवश्यकता है -

import requests
from bs4 import BeautifulSoup

इस कोड की निम्नलिखित पंक्ति में हम url के लिए GET HTTP अनुरोध बनाने के लिए अनुरोधों का उपयोग करते हैं: https://authoraditiagarwal.com/ GET अनुरोध करके।

r = requests.get('https://authoraditiagarwal.com/')

अब हमें निम्नानुसार सूप वस्तु बनाने की आवश्यकता है -

soup = BeautifulSoup(r.text, 'lxml')
print (soup.title)
print (soup.title.text)

उत्पादन

इसी आउटपुट को यहां दिखाया जाएगा -

<title>Learn and Grow with Aditi Agarwal</title>
Learn and Grow with Aditi Agarwal

lxml

एक और पायथन लाइब्रेरी जिसे हम वेब स्क्रैपिंग के लिए चर्चा करने जा रहे हैं वह है lxml। यह एक हाईपरफॉर्मेंस HTML और XML पार्सिंग लाइब्रेरी है। यह तुलनात्मक रूप से तेज और सीधा है। आप इसके बारे में और अधिक पढ़ सकते हैंhttps://lxml.de/.

Lxml स्थापित करना

पाइप कमांड का उपयोग करके, हम स्थापित कर सकते हैं lxml या तो हमारे आभासी वातावरण में या वैश्विक स्थापना में।

(base) D:\ProgramData>pip install lxml
Collecting lxml
   Downloading
https://files.pythonhosted.org/packages/b9/55/bcc78c70e8ba30f51b5495eb0e
3e949aa06e4a2de55b3de53dc9fa9653fa/lxml-4.2.5-cp36-cp36m-win_amd64.whl
(3.
6MB)
   100% |¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦| 3.6MB 64kB/s
Installing collected packages: lxml
Successfully installed lxml-4.2.5

उदाहरण: lxml और अनुरोधों का उपयोग करके डेटा निष्कर्षण

निम्नलिखित उदाहरण में, हम वेब पेज के एक विशेष तत्व को स्क्रैप कर रहे हैं authoraditiagarwal.com lxml और अनुरोधों का उपयोग करके -

सबसे पहले, हमें अनुरोध और HTML को lxml लाइब्रेरी से आयात करने की आवश्यकता है -

import requests
from lxml import html

अब हमें स्क्रैप करने के लिए वेब पेज का url प्रदान करने की आवश्यकता है

url = 'https://authoraditiagarwal.com/leadershipmanagement/'

अब हमें रास्ता प्रदान करने की आवश्यकता है (Xpath) उस वेब पेज के विशेष तत्व के लिए -

path = '//*[@id="panel-836-0-0-1"]/div/div/p[1]'
response = requests.get(url)
byte_string = response.content
source_code = html.fromstring(byte_string)
tree = source_code.xpath(path)
print(tree[0].text_content())

उत्पादन

इसी आउटपुट को यहां दिखाया जाएगा -

The Sprint Burndown or the Iteration Burndown chart is a powerful tool to communicate
daily progress to the stakeholders. It tracks the completion of work for a given sprint
or an iteration. The horizontal axis represents the days within a Sprint. The vertical 
axis represents the hours remaining to complete the committed work.