ดาวไม่ได้ใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งาน
 

             จากบทความ การใช้ตัวแปรดิคชันนารีเพื่อเก็บลิงค์และไตเติ้ลที่ได้จากการใช้งานโมดูลซิลิเนียม เราได้ทดลองการใช้การเก็บลิงค์และไตเติ้ลโดยใช้โมดูล Selenium (ซิลิเนี่ยม) และใช้ภาษาไพธอน กันไปบ้างแล้วในคราวนี้เราจะได้ลองกับเว็บอื่นๆบ้างๆซึ่งฟอร์มการเขียนโปรแกรมค่อนข้างคล้ายกันมากๆ 

 

กูเกิ้ลเสริช กับ โมดูล selenium (ซิลิเนียม)

              กูเกิ้ลเสริช คือเสริชเอ็นจิ้น ชนิดหนึ่งที่เราสามารถค้นหาสิ่งต่างๆที่เราต้องการได้ซึ่งถื่อว่าเป็นเสริชเอ็นจิ้นที่มีคุรภาพและผู้คนใช้งานกันอย่างมากมายและกว้างขวาง โดยในบทความนี้จะมาแนะนำหารใช้งานโมดูลซิลิเนียมกับกูเกิ้ลเสริชเอ็นจิ้น เพื่อเก็บลิงค์และไตเติ้ล ของสิ่งที่เราค้นหาทั้งหมด 

 

วิธีการเก็บลิงค์และไตเติ้ลในกูเกิ้ลเสริช โดยโมดูล selenium (ซิลิเนียม)

               1.เปิดหน้าเว็บและโครงสร้างหน้าเว็บที่เราต้องการเก็บลิงค์และไตเติ้ล   ในตัวอย่างจะเข้าถึงลิงค์และไตเติ้ลโดย XPath

 

               2.เขียนโปนแกรม

# -*- coding: utf-8 -*-
from selenium import webdriver
import time
driver = webdriver.Firefox(executable_path=r'C:\Users\BDC-CLUB\PycharmProjects\mdsoft\geckodriver.exe')
driver.get('https://www.google.com/') #เปิดหน้าเว้บที่ต้องการเก็บลิงค์และไตเติ้ล
a = driver.find_element_by_class_name('gsfi') #เข้าถึลงลิงค์และไตเติ้ลโดย XPath
a.send_keys("hello python")  #เสริชคำว่า "hello python"
a.submit()
time.sleep(3)
#xpath_topic= "//a[@class='topictitle']" #x path ของไตเติ้ล
xpath_topic= "//div//h3//a[@href]"
all_ids_topic = driver.find_elements_by_xpath(xpath_topic) #เก็บ sessionและelementไว้ในตัวแปร
print(all_ids_topic)
save_link = {} #กำหนดตัวแปรประเภาดิคชันนารี่
for i in all_ids_topic: #ลูปการเก็บลิงค์และไตเเติ้ล
    save_link[i.get_attribute('href')] = i.text
print(save_link) #ปริ้นไตเติ้ลและลิงค์

 

                 ผลการรัน:บรรทัดที่ 2 จะเก็บลิงค์และไตเติ้ลไว้

[<selenium.webdriver.firefox.webelement.FirefoxWebElement (session="be488680-fd78-415b-a63c-738e4b3cfa1d", element="4aa2c9a6-6f49-40e7-a899-c872a4f3e878")>, <selenium.webdriver.firefox.webelement.FirefoxWebElement (session="be488680-fd78-415b-a63c-738e4b3cfa1d", element="e96afca2-e233-43a9-b027-ac012d882b8c")>, <selenium.webdriver.firefox.webelement.FirefoxWebElement (session="be488680-fd78-415b-a63c-738e4b3cfa1d", element="edaad457-17ed-49e0-861e-2be6f9aa609a")>, <selenium.webdriver.firefox.webelement.FirefoxWebElement (session="be488680-fd78-415b-a63c-738e4b3cfa1d", element="aaa95ae7-b5f1-45d6-8d22-51cd4a6278dd")>, <selenium.webdriver.firefox.webelement.FirefoxWebElement (session="be488680-fd78-415b-a63c-738e4b3cfa1d", element="686a6a62-b4a1-4bf4-93af-ac3af47aee30")>, <selenium.webdriver.firefox.webelement.FirefoxWebElement (session="be488680-fd78-415b-a63c-738e4b3cfa1d", element="9d067a7b-1c89-41cf-8f19-ce43fd501a00")>, <selenium.webdriver.firefox.webelement.FirefoxWebElement (session="be488680-fd78-415b-a63c-738e4b3cfa1d", element="18082b58-c255-4dc1-931a-2e2f323edf13")>, <selenium.webdriver.firefox.webelement.FirefoxWebElement (session="be488680-fd78-415b-a63c-738e4b3cfa1d", element="9aedd82e-2b99-4139-8404-f9d896d88c4e")>, <selenium.webdriver.firefox.webelement.FirefoxWebElement (session="be488680-fd78-415b-a63c-738e4b3cfa1d", element="4df559a5-6e0d-495c-9433-5d14b7958ca0")>]
{'https://www.learnpython.org/en/Hello,_World!': 'Hello, World! - Learn Python - Free Interactive Python Tutorial', 'https://www.programiz.com/python-programming/examples/hello-world': 'Python Program to Print Hello world! - Programiz', 'https://learnpythonthehardway.org/book/ex1.html': 'Exercise 1: A Good First Program - Learn Python the Hard Way', 'https://www.hackerrank.com/challenges/py-hello-world': 'Say "Hello, World!" With Python | HackerRank', 'https://www.amazon.com/Hello-Python-Anthony-S-Briggs/dp/1935182080': 'Hello! Python: Anthony S. Briggs: 0884771505755: Amazon.com: Books', 'https://www.guru99.com/creating-your-first-python-program.html': 'Hello World: Create your First Python Program - Guru99', 'https://www.digitalocean.com/community/tutorials/how-to-write-your-first-python-3-program': 'How To Write a Hello World Program in Python 3 | DigitalOcean', 'https://www.manning.com/books/hello-python': 'Manning | Hello! Python', 'https://www.kaggle.com/colinmorris/hello-python': 'Hello, Python | Kaggle'}
กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
แนะนำฟีเจอร์ Coupons ของ MooZiiCart ตัวช่วย ทำ คูปองส่วนลด ในเว็บขายของ สำหรับร้านค้าออนไลน์ ที่จะกระตุ้นยอดขายบางช่วง
โดย prmindphp ส 07 ธ.ค. 2019 3:56 pm บอร์ด MindPHP News & Feedback
0
37
ส 07 ธ.ค. 2019 3:56 pm โดย prmindphp
ใน ปล๊กอิน เราสามารถนำข้อความในไฟล์ภาษาออกมาแสดงได้อย่างไร ครับ
โดย jamepiyawat ส 07 ธ.ค. 2019 2:21 pm บอร์ด Joomla Development
0
17
ส 07 ธ.ค. 2019 2:21 pm โดย jamepiyawat
Block IP เข้าเว็บ เซิร์ฟเวอร์ เป็นข่วง ด้วย .htaccess
โดย mindphp ส 07 ธ.ค. 2019 2:12 pm บอร์ด Linux - Web Server
2
1426
อ 08 ธ.ค. 2019 11:17 am โดย mindphp
ภาพประกอบ Extensions
โดย numtan5839 ส 07 ธ.ค. 2019 11:19 am บอร์ด M097 - ตรีเนตร บูรณโพธิ์ทอง
0
3
ส 07 ธ.ค. 2019 11:19 am โดย numtan5839
งานประจำวันที่ 7 ธันวาคม 2562
โดย numtan5839 ส 07 ธ.ค. 2019 10:15 am บอร์ด M097 - ตรีเนตร บูรณโพธิ์ทอง
3
11
ส 07 ธ.ค. 2019 7:02 pm โดย numtan5839
งานประจำวันที่ 7 ธันวาคม 2562
โดย Grammanano ส 07 ธ.ค. 2019 10:05 am บอร์ด M098 - อนงค์นาท ไฝขาว
6
32
อ 08 ธ.ค. 2019 4:40 pm โดย mindphp
คำว่า extension ผิดค่ะ
โดย numtan5839 ศ 06 ธ.ค. 2019 8:17 pm บอร์ด MindPHP News & Feedback
1
26
ส 07 ธ.ค. 2019 1:20 am โดย mindphp
ทำอย่างไรให้ google slide นั้นสามารถแสดงหน้าที่เรากำหนดได้ ผ่าน url ครับ
โดย jamepiyawat ศ 06 ธ.ค. 2019 5:23 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
2
1617
จ 09 ธ.ค. 2019 10:17 am โดย jamepiyawat
การทำนายข้อมูลแบบ Dicision Tree ด้วยโปรแกรม Weka
โดย Grammanano ศ 06 ธ.ค. 2019 5:16 pm บอร์ด Share Knowledge
0
17
ศ 06 ธ.ค. 2019 5:16 pm โดย Grammanano
ทำไม แปลงวันเดือนปีเป็นวันที่ ตามระบบของ Joomla แล้ววันถึงถอยไปวันหนึ่งครับ
โดย jamepiyawat ศ 06 ธ.ค. 2019 3:23 pm บอร์ด Joomla Development
1
23
ศ 06 ธ.ค. 2019 4:51 pm โดย thatsawan
คำสั่งพื้นฐานในการใช้ Matlab เพื่อการทำ Image Processing
โดย Grammanano ศ 06 ธ.ค. 2019 3:20 pm บอร์ด Share Knowledge
0
1431
ศ 06 ธ.ค. 2019 3:20 pm โดย Grammanano
Introducing the Module Weather Forcecast.
โดย numtan5839 ศ 06 ธ.ค. 2019 2:34 pm บอร์ด M097 - ตรีเนตร บูรณโพธิ์ทอง
3
14
ส 07 ธ.ค. 2019 3:25 pm โดย numtan5839
เขียนบทความ แต่พอ save แล้วเนื้อหาไม่แสดง
โดย numtan5839 ศ 06 ธ.ค. 2019 2:30 pm บอร์ด MindPHP News & Feedback
0
16
ศ 06 ธ.ค. 2019 2:30 pm โดย numtan5839
จะทำอย่างไรให้ดึงข้อความ 10 ตัวท้ายได้ครับ
โดย jamepiyawat ศ 06 ธ.ค. 2019 11:39 am บอร์ด Programming - PHP
3
1432
ศ 06 ธ.ค. 2019 2:04 pm โดย jamepiyawat
จะทำอย่างไรให้ Plugin Content Change Log แสดงข้อความด้านบนได้ ครับ
โดย jamepiyawat ศ 06 ธ.ค. 2019 11:03 am บอร์ด Joomla Development
1
1427
ศ 06 ธ.ค. 2019 7:42 pm โดย thatsawan
งานประจำวันที่ 6 ธันวาคม 2562
โดย Grammanano ศ 06 ธ.ค. 2019 9:43 am บอร์ด M098 - อนงค์นาท ไฝขาว
5
33
ส 07 ธ.ค. 2019 6:59 pm โดย Grammanano
งานประจำวันที่ 6 ธันวาคม 2562
โดย numtan5839 ศ 06 ธ.ค. 2019 9:34 am บอร์ด M097 - ตรีเนตร บูรณโพธิ์ทอง
10
35
ศ 06 ธ.ค. 2019 7:42 pm โดย numtan5839
เปิดตัวเว็บบอร์ด รูปแบบใหม่ ของเรา มีอะไรมาใหม่ ลองมาดูกัน เราใช้ phpBB 3.2 นะ
โดย mindphp พ 04 ธ.ค. 2019 7:44 pm บอร์ด MindPHP News & Feedback
1
1445
พ 04 ธ.ค. 2019 8:03 pm โดย thatsawan
วิธีการ ใช้งาน Jquery คำนวณเลขฐาน 2 8 16
โดย Ittichai_chupol พ 04 ธ.ค. 2019 6:58 pm บอร์ด Jquery & Ajax Knowledge
0
953
พ 04 ธ.ค. 2019 6:58 pm โดย Ittichai_chupol
การใช้บอร์ด Arduino ต่อกับเซ็นเซอร์สี TCS3200
โดย Grammanano พ 04 ธ.ค. 2019 6:54 pm บอร์ด Share Knowledge
0
18
พ 04 ธ.ค. 2019 6:54 pm โดย Grammanano