प्रसंस्करण छवियाँ और वीडियो

वेब स्क्रैपिंग में आमतौर पर वेब मीडिया सामग्री को डाउनलोड, भंडारण और प्रसंस्करण शामिल होता है। इस अध्याय में, हम समझते हैं कि वेब से डाउनलोड की गई सामग्री को कैसे संसाधित किया जाए।

परिचय

वेब मीडिया सामग्री जो हम स्क्रैपिंग के दौरान प्राप्त करते हैं, वे गैर-वेब पृष्ठों के साथ-साथ डेटा फ़ाइलों के रूप में चित्र, ऑडियो और वीडियो फाइलें हो सकती हैं। लेकिन, क्या हम डाउनलोड किए गए डेटा पर विशेष रूप से उस डेटा के विस्तार पर भरोसा कर सकते हैं जिसे हम अपनी कंप्यूटर मेमोरी में डाउनलोड और स्टोर करने जा रहे हैं? इससे यह जानना आवश्यक हो जाता है कि हम किस प्रकार के डेटा को स्थानीय स्तर पर स्टोर करने जा रहे हैं।

वेब पेज से मीडिया सामग्री प्राप्त करना

इस खंड में, हम यह जानने जा रहे हैं कि हम मीडिया सामग्री को कैसे डाउनलोड कर सकते हैं जो वेब सर्वर से मिली जानकारी के आधार पर मीडिया प्रकार का सही प्रतिनिधित्व करती है। हम इसे पायथन की मदद से कर सकते हैंrequests मॉड्यूल जैसा कि हमने पिछले अध्याय में किया था।

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

import requests

अब, उस मीडिया सामग्री का URL प्रदान करें जिसे हम स्थानीय रूप से डाउनलोड और संग्रहीत करना चाहते हैं।

url = "https://authoraditiagarwal.com/wpcontent/uploads/2018/05/MetaSlider_ThinkBig-1080x180.jpg"

HTTP प्रतिक्रिया ऑब्जेक्ट बनाने के लिए निम्न कोड का उपयोग करें।

r = requests.get(url)

निम्नलिखित लाइन ऑफ़ कोड की मदद से, हम प्राप्त सामग्री को .png फ़ाइल के रूप में सहेज सकते हैं।

with open("ThinkBig.png",'wb') as f:
   f.write(r.content)

उपरोक्त पायथन स्क्रिप्ट को चलाने के बाद, हमें ThinkBig.png नामक एक फ़ाइल मिलेगी, जिसमें डाउनलोड की गई छवि होगी।

URL से फ़ाइल नाम निकालना

वेब साइट से सामग्री डाउनलोड करने के बाद, हम इसे URL में फ़ाइल नाम के साथ फ़ाइल में सहेजना चाहते हैं। लेकिन हम यह भी जाँच सकते हैं, यदि अतिरिक्त टुकड़ों की संख्या URL में भी मौजूद है। इसके लिए, हमें URL से वास्तविक फ़ाइल नाम खोजने की आवश्यकता है।

पायथन लिपि की मदद से, का उपयोग कर urlparse, हम URL से फ़ाइल नाम निकाल सकते हैं -

import urllib3
import os
url = "https://authoraditiagarwal.com/wpcontent/uploads/2018/05/MetaSlider_ThinkBig-1080x180.jpg"
a = urlparse(url)
a.path

आप नीचे दिखाए अनुसार आउटपुट का अवलोकन कर सकते हैं -

'/wp-content/uploads/2018/05/MetaSlider_ThinkBig-1080x180.jpg'
os.path.basename(a.path)

आप नीचे दिखाए अनुसार आउटपुट का अवलोकन कर सकते हैं -

'MetaSlider_ThinkBig-1080x180.jpg'

एक बार जब आप उपरोक्त स्क्रिप्ट चलाते हैं, तो हमें URL से फ़ाइल नाम मिल जाएगा।

URL से सामग्री के प्रकार के बारे में जानकारी

वेब सर्वर से सामग्री निकालते समय, GET अनुरोध द्वारा, हम वेब सर्वर द्वारा प्रदान की गई इसकी जानकारी की भी जांच कर सकते हैं। निम्नलिखित पायथन लिपि की मदद से हम यह निर्धारित कर सकते हैं कि वेब सर्वर सामग्री के प्रकार के साथ क्या करता है -

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

import requests

अब, हमें उस मीडिया सामग्री का URL प्रदान करना होगा जिसे हम स्थानीय रूप से डाउनलोड और संग्रहीत करना चाहते हैं।

url = "https://authoraditiagarwal.com/wpcontent/uploads/2018/05/MetaSlider_ThinkBig-1080x180.jpg"

कोड की लाइन के बाद HTTP प्रतिक्रिया ऑब्जेक्ट बनेगा।

r = requests.get(url, allow_redirects=True)

अब, हम वेब सर्वर द्वारा सामग्री के बारे में किस प्रकार की जानकारी प्रदान की जा सकती है।

for headers in r.headers: print(headers)

आप नीचे दिखाए अनुसार आउटपुट का अवलोकन कर सकते हैं -

Date
Server
Upgrade
Connection
Last-Modified
Accept-Ranges
Content-Length
Keep-Alive
Content-Type

निम्नलिखित कोड की मदद से हम सामग्री प्रकार के बारे में विशेष जानकारी प्राप्त कर सकते हैं, सामग्री प्रकार कह सकते हैं -

print (r.headers.get('content-type'))

आप नीचे दिखाए अनुसार आउटपुट का अवलोकन कर सकते हैं -

image/jpeg

निम्नलिखित प्रकार की कोड की मदद से, हम सामग्री प्रकार के बारे में विशेष जानकारी प्राप्त कर सकते हैं, EType कहते हैं -

print (r.headers.get('ETag'))

आप नीचे दिखाए अनुसार आउटपुट का अवलोकन कर सकते हैं -

None

निम्नलिखित आदेश का पालन करें -

print (r.headers.get('content-length'))

आप नीचे दिखाए अनुसार आउटपुट का अवलोकन कर सकते हैं -

12636

निम्नलिखित कोड की मदद से हम सामग्री प्रकार के बारे में विशेष जानकारी प्राप्त कर सकते हैं, सर्वर कहते हैं -

print (r.headers.get('Server'))

आप नीचे दिखाए अनुसार आउटपुट का अवलोकन कर सकते हैं -

Apache

छवियों के लिए थंबनेल उत्पन्न करना

थंबनेल एक बहुत छोटा विवरण या प्रतिनिधित्व है। कोई उपयोगकर्ता केवल एक बड़ी छवि के थंबनेल को सहेजना चाहता है या दोनों को छवि के साथ-साथ थंबनेल को भी सहेजना चाहता है। इस खंड में हम नाम की छवि का एक थंबनेल बनाने जा रहे हैंThinkBig.png पिछले भाग में डाउनलोड किया गया "वेब पेज से मीडिया सामग्री प्राप्त करना"।

इस पायथन लिपि के लिए, हमें पाइलट नामक पायथन लाइब्रेरी स्थापित करने की आवश्यकता है, पायथन इमेज लाइब्रेरी का एक कांटा जिसमें छवियों के हेरफेर के लिए उपयोगी कार्य हैं। इसे निम्नलिखित कमांड की सहायता से स्थापित किया जा सकता है -

pip install pillow

निम्नलिखित पायथन लिपि छवि का एक थंबनेल बनाएगी और इसे थंबनेल फ़ाइल के साथ प्रीफ़िक्स करके वर्तमान निर्देशिका में सहेजेगी Th_

import glob
from PIL import Image
for infile in glob.glob("ThinkBig.png"):
   img = Image.open(infile)
   img.thumbnail((128, 128), Image.ANTIALIAS)
   if infile[0:2] != "Th_":
      img.save("Th_" + infile, "png")

उपरोक्त कोड समझने में बहुत आसान है और आप वर्तमान निर्देशिका में थंबनेल फ़ाइल के लिए जाँच कर सकते हैं।

वेबसाइट से स्क्रीनशॉट

वेब स्क्रैपिंग में, एक वेबसाइट का स्क्रीनशॉट लेना एक बहुत ही सामान्य कार्य है। इसे लागू करने के लिए, हम सेलेनियम और वेबड्राइवर का उपयोग करने जा रहे हैं। निम्नलिखित पायथन स्क्रिप्ट वेबसाइट से स्क्रीनशॉट लेगी और इसे वर्तमान निर्देशिका में सहेजेगी।

From selenium import webdriver
path = r'C:\\Users\\gaurav\\Desktop\\Chromedriver'
browser = webdriver.Chrome(executable_path = path)
browser.get('https://tutorialspoint.com/')
screenshot = browser.save_screenshot('screenshot.png')
browser.quit

आप नीचे दिखाए अनुसार आउटपुट का अवलोकन कर सकते हैं -

DevTools listening on ws://127.0.0.1:1456/devtools/browser/488ed704-9f1b-44f0-
a571-892dc4c90eb7
<bound method WebDriver.quit of <selenium.webdriver.chrome.webdriver.WebDriver
(session="37e8e440e2f7807ef41ca7aa20ce7c97")>>

स्क्रिप्ट चलाने के बाद, आप अपनी वर्तमान निर्देशिका की जांच कर सकते हैं screenshot.png फ़ाइल।

वीडियो के लिए थंबनेल जेनरेशन

मान लीजिए कि हमने वेबसाइट से वीडियो डाउनलोड किए हैं और उनके लिए थंबनेल तैयार करना चाहते हैं ताकि उसके थंबनेल के आधार पर एक विशिष्ट वीडियो पर क्लिक किया जा सके। वीडियो के लिए थंबनेल जेनरेट करने के लिए हमें एक सरल टूल की आवश्यकता होती है जिसे कॉल किया जाता हैffmpeg जिसे से डाउनलोड किया जा सकता है www.ffmpeg.org। डाउनलोड करने के बाद, हमें अपने ओएस के विनिर्देशों के अनुसार इसे स्थापित करने की आवश्यकता है।

निम्नलिखित पायथन लिपि वीडियो का थंबनेल उत्पन्न करेगी और इसे हमारी स्थानीय निर्देशिका में सहेजेगी -

import subprocess
video_MP4_file = “C:\Users\gaurav\desktop\solar.mp4
thumbnail_image_file = 'thumbnail_solar_video.jpg'
subprocess.call(['ffmpeg', '-i', video_MP4_file, '-ss', '00:00:20.000', '-
   vframes', '1', thumbnail_image_file, "-y"])

उपरोक्त स्क्रिप्ट को चलाने के बाद, हमें थंबनेल नाम मिलेगा thumbnail_solar_video.jpg हमारी स्थानीय निर्देशिका में सहेजा गया।

एक एमपी 3 के लिए एक MP4 वीडियो तेजस्वी

मान लीजिए कि आपने किसी वेबसाइट से कुछ वीडियो फ़ाइल डाउनलोड की है, लेकिन आपको अपने उद्देश्य की पूर्ति के लिए केवल उस फ़ाइल से ऑडियो की आवश्यकता है, तो इसे पायथन लाइब्रेरी की सहायता से पायथन में किया जा सकता है moviepy जिसे निम्नलिखित कमांड की सहायता से स्थापित किया जा सकता है -

pip install moviepy

अब, निम्नलिखित स्क्रिप्ट की मदद से मूवीपी को सफलतापूर्वक स्थापित करने के बाद हम एमपी 3 में कनवर्ट कर सकते हैं और एमपी 3 को बदल सकते हैं।

import moviepy.editor as mp
clip = mp.VideoFileClip(r"C:\Users\gaurav\Desktop\1234.mp4")
clip.audio.write_audiofile("movie_audio.mp3")

आप नीचे दिखाए अनुसार आउटपुट का अवलोकन कर सकते हैं -

[MoviePy] Writing audio in movie_audio.mp3
100%|¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦
¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦¦| 674/674 [00:01<00:00,
476.30it/s]
[MoviePy] Done.

उपरोक्त स्क्रिप्ट स्थानीय निर्देशिका में ऑडियो एमपी 3 फ़ाइल को बचाएगा।