Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Piękna zupa webscrape do mysql

Jest więc kilka rzeczy do omówienia.

dokumentacja na temat PyMySQL są całkiem dobrzy w uruchamianiu i uruchamianiu.

Zanim jednak będziesz mógł umieścić te rzeczy w bazie danych, musisz je pobrać w taki sposób, aby wykonawca i nazwa utworu były ze sobą powiązane. W tej chwili otrzymujesz osobną listę wykonawców i piosenek, bez możliwości ich powiązania. Aby to zrobić, będziesz chciał przejść przez klasę tytułowego wykonawcy.

Zrobiłbym to w ten sposób -

from urllib import urlopen
from bs4 import BeautifulSoup
import pymysql.cursors

# Webpage connection
html = urlopen("http://www.officialcharts.com/charts/singles-chart/19800203/7501/")

# Grab title-artist classes and iterate
bsObj = BeautifulSoup(html)
recordList = bsObj.findAll("div", {"class" : "title-artist",})

# Now iterate over recordList to grab title and artist
for record in recordList:
     title = record.find("div", {"class": "title",}).get_text().strip()
     artist = record.find("div", {"class": "artist"}).get_text().strip()
     print artist + ': ' + title

Spowoduje to wydrukowanie tytułu i wykonawcy dla każdej iteracji pętli RecordList.

Aby wstawić te wartości do bazy danych MySQL, stworzyłem tabelę o nazwie artist_song z następującym:

CREATE TABLE `artist_song` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `artist` varchar(255) COLLATE utf8_bin NOT NULL,
  `song` varchar(255) COLLATE utf8_bin NOT NULL,
  PRIMARY KEY (`id`)
  ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin
  AUTO_INCREMENT=1;

Nie jest to najczystszy sposób, ale pomysł jest zdrowy. Chcemy otworzyć połączenie z bazą danych MySQL (nazwałem moją DB top_40) i wstawić parę wykonawca/tytuł dla każdej iteracji pętli recordList:

from urllib import urlopen
from bs4 import BeautifulSoup
import pymysql.cursors


# Webpage connection
html = urlopen("http://www.officialcharts.com/charts/singles-chart/19800203/7501/")

# Grab title-artist classes and store in recordList
bsObj = BeautifulSoup(html)
recordList = bsObj.findAll("div", {"class" : "title-artist",})

# Create a pymysql cursor and iterate over each title-artist record.
# This will create an INSERT statement for each artist/pair, then commit
# the transaction after reaching the end of the list. pymysql does not
# have autocommit enabled by default. After committing it will close
# the database connection.
# Create database connection

connection = pymysql.connect(host='localhost',
                             user='root',
                             password='password',
                             db='top_40',
                             charset='utf8mb4',
                             cursorclass=pymysql.cursors.DictCursor)

try:
    with connection.cursor() as cursor:
        for record in recordList:
            title = record.find("div", {"class": "title",}).get_text().strip()
            artist = record.find("div", {"class": "artist"}).get_text().strip()
            sql = "INSERT INTO `artist_song` (`artist`, `song`) VALUES (%s, %s)"
            cursor.execute(sql, (artist, title))
    connection.commit()
finally:
    connection.close()

Edycja:Zgodnie z moim komentarzem uważam, że łatwiej jest iterować po wierszach tabeli:

from urllib import urlopen
from bs4 import BeautifulSoup
import pymysql.cursors


# Webpage connection
html = urlopen("http://www.officialcharts.com/charts/singles-chart/19800203/7501/")

bsObj = BeautifulSoup(html)

rows = bsObj.findAll('tr')
for row in rows:
    if row.find('span', {'class' : 'position'}):
        position = row.find('span', {'class' : 'position'}).get_text().strip()
        artist = row.find('div', {'class' : 'artist'}).get_text().strip()
        track = row.find('div', {'class' : 'title'}).get_text().strip()



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. MySQL:Przytnij tabelę vs Usuń z tabeli

  2. mysql Błąd krytyczny:nie można przydzielić pamięci dla puli buforów

  3. zapytanie pobierania mysql w Pythonie

  4. Pytanie MySQL - Unikalny klucz Nie działa poprawnie, czy nie rozumiem?

  5. MySQL REPLACE :Jak zastąpić wszystkie wystąpienia znaku w każdym odrębnym podciągu rozdzielonym tym samym nagłówkiem i ogonem