अजगर वेब स्क्रैपिंग - डाटा प्रोसेसिंग
पहले के अध्यायों में, हमने विभिन्न पायथन मॉड्यूल द्वारा वेब पेज या वेब स्क्रैपिंग से डेटा निकालने के बारे में सीखा। इस अध्याय में, डेटा को स्क्रैप करने के लिए विभिन्न तकनीकों पर ध्यान दें।
परिचय
स्क्रैप किए गए डेटा को संसाधित करने के लिए, हमें अपने स्थानीय मशीन पर स्प्रेडशीट (CSV), JSON या कभी-कभी MySQL जैसे डेटाबेस में किसी विशेष प्रारूप में डेटा संग्रहीत करना चाहिए।
CSV और JSON डाटा प्रोसेसिंग
सबसे पहले, हम वेब पेज से सीएसवी फ़ाइल या स्प्रेडशीट में हथियाने के बाद, जानकारी लिखने जा रहे हैं। आइए पहले हम एक सरल उदाहरण के माध्यम से समझते हैं जिसमें हम पहले सूचना का उपयोग करके पकड़ लेंगेBeautifulSoup मॉड्यूल, जैसा कि पहले किया था, और फिर पायथन सीएसवी मॉड्यूल का उपयोग करके हम उस पाठ्य सूचना को सीएसवी फ़ाइल में लिखेंगे।
सबसे पहले, हमें आवश्यक अजगर पुस्तकालयों को निम्नानुसार आयात करना होगा -
import requests
from bs4 import BeautifulSoup
import csv
इस कोड की निम्नलिखित पंक्ति में, हम url के लिए GET HTTP अनुरोध बनाने के लिए अनुरोधों का उपयोग करते हैं: https://authoraditiagarwal.com/ GET अनुरोध करके।
r = requests.get('https://authoraditiagarwal.com/')
अब, हमें निम्नानुसार एक सूप ऑब्जेक्ट बनाने की आवश्यकता है -
soup = BeautifulSoup(r.text, 'lxml')
अब, कोड की अगली पंक्तियों की सहायता से, हम डेटा को CSV फ़ाइल में dataprocessing.csv नाम से लिखेंगे।
f = csv.writer(open(' dataprocessing.csv ','w'))
f.writerow(['Title'])
f.writerow([soup.title.text])
इस स्क्रिप्ट को चलाने के बाद, आपके स्थानीय मशीन पर उपर्युक्त CSV फ़ाइल की पाठ्य सूचना या वेबपेज का शीर्षक सहेजा जाएगा।
इसी प्रकार, हम एकत्रित जानकारी को JSON फ़ाइल में सहेज सकते हैं। निम्नलिखित पायथन लिपि को समझने के लिए एक आसान काम है जिसमें हम वही जानकारी ले रहे हैं जैसा कि हमने पिछले पायथन लिपि में किया था, लेकिन इस बार JSONfile.txt में JSON Python मॉड्यूल का उपयोग करके हड़पी गई जानकारी को बचाया जाता है।
import requests
from bs4 import BeautifulSoup
import csv
import json
r = requests.get('https://authoraditiagarwal.com/')
soup = BeautifulSoup(r.text, 'lxml')
y = json.dumps(soup.title.text)
with open('JSONFile.txt', 'wt') as outfile:
json.dump(y, outfile)
इस स्क्रिप्ट को चलाने के बाद, आपके स्थानीय मशीन पर उपर्युक्त पाठ फ़ाइल में वेबपेज का पकड़ा हुआ जानकारी अर्थात शीर्षक सहेजा जाएगा।
AWS S3 का उपयोग करके डाटा प्रोसेसिंग
कभी-कभी हम संग्रह के उद्देश्य से अपने स्थानीय संग्रहण में स्क्रैप किए गए डेटा को सहेजना चाहते हैं। लेकिन क्या होगा अगर हमें बड़े पैमाने पर इस डेटा को स्टोर और विश्लेषण करने की आवश्यकता है? उत्तर क्लाउड स्टोरेज सेवा है जिसका नाम Amazon S3 या AWS S3 (सिंपल स्टोरेज सर्विस) है। मूल रूप से AWS S3 एक ऑब्जेक्ट स्टोरेज है जो कहीं से भी किसी भी डेटा को स्टोर करने और पुनः प्राप्त करने के लिए बनाया गया है।
हम AWS S3 में डेटा संग्रहीत करने के लिए निम्नलिखित चरणों का पालन कर सकते हैं -
Step 1- पहले हमें एक एडब्ल्यूएस खाते की आवश्यकता होती है जो डेटा संग्रहीत करते समय हमारी पायथन स्क्रिप्ट में उपयोग करने के लिए गुप्त कुंजी प्रदान करेगा। यह एक S3 बाल्टी बनाएगा जिसमें हम अपना डेटा स्टोर कर सकते हैं।
Step 2 - अगला, हमें स्थापित करने की आवश्यकता है boto3S3 बाल्टी तक पहुँचने के लिए पायथन लाइब्रेरी। इसे निम्नलिखित कमांड की सहायता से स्थापित किया जा सकता है -
pip install boto3
Step 3 - अगला, हम वेब पेज से डेटा को स्क्रैप करने और इसे AWS S3 बाल्टी में सहेजने के लिए निम्न पायथन स्क्रिप्ट का उपयोग कर सकते हैं।
सबसे पहले, हमें स्क्रैपिंग के लिए पायथन पुस्तकालयों को आयात करने की आवश्यकता है, यहां हम साथ काम कर रहे हैं requests, तथा boto3 S3 बाल्टी के लिए डेटा की बचत।
import requests
import boto3
अब हम अपने URL से डेटा को स्क्रैप कर सकते हैं।
data = requests.get("Enter the URL").text
अब डेटा को S3 बाल्टी में संग्रहीत करने के लिए, हमें S3 क्लाइंट बनाने की आवश्यकता है -
s3 = boto3.client('s3')
bucket_name = "our-content"
कोड की अगली पंक्ति निम्नानुसार S3 बाल्टी बनाएगी -
s3.create_bucket(Bucket = bucket_name, ACL = 'public-read')
s3.put_object(Bucket = bucket_name, Key = '', Body = data, ACL = "public-read")
अब आप अपने AWS खाते से हमारी सामग्री के नाम के साथ बाल्टी की जांच कर सकते हैं।
MySQL का उपयोग करके डेटा प्रोसेसिंग
आइए जानें कि MySQL का उपयोग करके डेटा को कैसे प्रोसेस किया जाए। यदि आप MySQL के बारे में सीखना चाहते हैं, तो आप लिंक का अनुसरण कर सकते हैंhttps://www.tutorialspoint.com/mysql/.
निम्नलिखित चरणों की मदद से, हम डेटा को MySQL तालिका में परिमार्जन और संसाधित कर सकते हैं -
Step 1- सबसे पहले, MySQL का उपयोग करके हमें एक डेटाबेस और तालिका बनाने की आवश्यकता है जिसमें हम अपने स्क्रैप किए गए डेटा को सहेजना चाहते हैं। उदाहरण के लिए, हम निम्नलिखित क्वेरी के साथ तालिका बना रहे हैं -
CREATE TABLE Scrap_pages (id BIGINT(7) NOT NULL AUTO_INCREMENT,
title VARCHAR(200), content VARCHAR(10000),PRIMARY KEY(id));
Step 2- अगला, हमें यूनिकोड से निपटने की आवश्यकता है। ध्यान दें कि MySQL डिफ़ॉल्ट रूप से यूनिकोड को संभालता नहीं है। हमें निम्नलिखित कमांड की मदद से इस सुविधा को चालू करना होगा जो डेटाबेस के लिए तयशुदा चरित्र को बदल देगा, तालिका के लिए और दोनों कॉलम के लिए -
ALTER DATABASE scrap CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;
ALTER TABLE Scrap_pages CONVERT TO CHARACTER SET utf8mb4 COLLATE
utf8mb4_unicode_ci;
ALTER TABLE Scrap_pages CHANGE title title VARCHAR(200) CHARACTER SET utf8mb4
COLLATE utf8mb4_unicode_ci;
ALTER TABLE pages CHANGE content content VARCHAR(10000) CHARACTER SET utf8mb4
COLLATE utf8mb4_unicode_ci;
Step 3- अब, MySQL को पायथन के साथ एकीकृत करें। इसके लिए, हमें PyMySQL की आवश्यकता होगी जिसे निम्नलिखित कमांड की सहायता से स्थापित किया जा सकता है
pip install PyMySQL
Step 4- अब, स्क्रैप नाम का हमारा डेटाबेस, पहले बनाया गया था, वेब से स्क्रैप होने के बाद, स्क्रैप-पेपेज नामक तालिका में, डेटा को बचाने के लिए तैयार है। यहां हमारे उदाहरण में हम विकिपीडिया से डेटा खंगालने जा रहे हैं और इसे हमारे डेटाबेस में सहेजा जाएगा।
सबसे पहले, हमें आवश्यक पायथन मॉड्यूल को आयात करना होगा।
from urllib.request import urlopen
from bs4 import BeautifulSoup
import datetime
import random
import pymysql
import re
अब, एक कनेक्शन बनाएं, जो इसे पायथन के साथ एकीकृत करता है।
conn = pymysql.connect(host='127.0.0.1',user='root', passwd = None, db = 'mysql',
charset = 'utf8')
cur = conn.cursor()
cur.execute("USE scrap")
random.seed(datetime.datetime.now())
def store(title, content):
cur.execute('INSERT INTO scrap_pages (title, content) VALUES ''("%s","%s")', (title, content))
cur.connection.commit()
अब, विकिपीडिया के साथ जुड़ें और इससे डेटा प्राप्त करें।
def getLinks(articleUrl):
html = urlopen('http://en.wikipedia.org'+articleUrl)
bs = BeautifulSoup(html, 'html.parser')
title = bs.find('h1').get_text()
content = bs.find('div', {'id':'mw-content-text'}).find('p').get_text()
store(title, content)
return bs.find('div', {'id':'bodyContent'}).findAll('a',href=re.compile('^(/wiki/)((?!:).)*$'))
links = getLinks('/wiki/Kevin_Bacon')
try:
while len(links) > 0:
newArticle = links[random.randint(0, len(links)-1)].attrs['href']
print(newArticle)
links = getLinks(newArticle)
अंत में, हमें कर्सर और कनेक्शन दोनों को बंद करने की आवश्यकता है।
finally:
cur.close()
conn.close()
यह विकिपीडिया से डेटा इकट्ठा करने के लिए स्क्रैप_पेज नाम की तालिका में बचाएगा। यदि आप MySQL और वेब स्क्रैपिंग से परिचित हैं, तो उपरोक्त कोड को समझना कठिन नहीं होगा।
PostgreSQL का उपयोग करके डेटा प्रोसेसिंग
PostgreSQL, स्वयंसेवकों की एक विश्वव्यापी टीम द्वारा विकसित, एक खुला स्रोत रिलेशनल डेटाबेस मैनेजमेंट सिस्टम (RDMS) है। PostgreSQL का उपयोग करके स्क्रैप किए गए डेटा को संसाधित करने की प्रक्रिया MySQL के समान है। दो बदलाव होंगे: पहला, कमांड MySQL के लिए अलग होगा और दूसरा, यहाँ हम उपयोग करेंगेpsycopg2 पायथन पुस्तकालय ने पायथन के साथ अपना एकीकरण करने के लिए।
अगर आप PostgreSQL से परिचित नहीं हैं तो आप इसे सीख सकते हैं https://www.tutorialspoint.com/postgresql/. और निम्नलिखित कमांड की सहायता से हम psycopg2 Python लाइब्रेरी स्थापित कर सकते हैं -
pip install psycopg2