Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 | 31 |
Tags
- 자바 강제 캐스팅
- 자바 삼항연산자
- 자바 public
- Til
- 자바 while문
- 항해99
- 자바 향상된 for문
- 변수
- 이클립스 DB연동
- 자바
- java
- Vue3
- 항해99 2기
- 자바 switch문
- MySQL
- 자바 for문
- TypeScript
- 자바 if문
- 자바 스캐너
- 정보처리기사실기
- react with typescript
- 자바 구구단 출력
- react ag grid
- 조코딩
- 자바 자동캐스팅
- 타입스크립트
- 자바 반복문
- 프로그래머스
- 자바 공배수
- 자바 조건문
Archives
- Today
- Total
뇌 채우기 공간
[python] pymongo, 크롤링한 데이터를 db에 저장하고 찾고 수정하기 본문
from builtins import print
import requests
from bs4 import BeautifulSoup
from pymongo import MongoClient
client = MongoClient('localhost', 27017)
db = client.dbsparta
headers = {'User-Agent' : 'Mozilla/5.0 (Windows NT 10.0; Win64; x64)AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.86 Safari/537.36'}
data = requests.get('https://movie.naver.com/movie/sdb/rank/rmovie.nhn?sel=pnt&date=20200303',headers=headers)
soup = BeautifulSoup(data.text, 'html.parser')
trs = soup.select('#old_content > table > tbody > tr')
for tr in trs:
a_tag = tr.select_one('td.title > div > a')
if a_tag is not None:
title = a_tag.text
rank = tr.select_one('td:nth-child(1) > img')['alt']
point = tr.select_one('td.point').text
doc = {
'rank': rank,
'title': title,
'point': point
}
db.movies.insert_one(doc)
from builtins import print
import requests
from bs4 import BeautifulSoup
from pymongo import MongoClient
client = MongoClient('localhost', 27017)
db = client.dbsparta
headers = {'User-Agent' : 'Mozilla/5.0 (Windows NT 10.0; Win64; x64)AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.86 Safari/537.36'}
data = requests.get('https://movie.naver.com/movie/sdb/rank/rmovie.nhn?sel=pnt&date=20200303',headers=headers)
soup = BeautifulSoup(data.text, 'html.parser')
trs = soup.select('#old_content > table > tbody > tr')
# for tr in trs:
#
# a_tag = tr.select_one('td.title > div > a')
#
# if a_tag is not None:
# title = a_tag.text
# rank = tr.select_one('td:nth-child(1) > img')['alt']
# point = tr.select_one('td.point').text
# doc = {
# 'rank': rank,
# 'title': title,
# 'point': point
# }
# db.movies.insert_one(doc)
# 매트릭스의 평점 가져오기
metrix = db.movies.find_one({'title':'매트릭스'})
print(metrix['point'])
# 매트릭스의 평점과 같은 평점인 영화 제목 가져오기
same_points = list(db.movies.find({'point':metrix['point']},{'_id':False}))
for same in same_points:
print(same['title'])
# 매트릭스 영화의 평점을 0으로 만들기
db.movies.update_one({'title':'매트릭스'},{'$set':{'point':'0'}})
728x90
'WEB > python' 카테고리의 다른 글
[python] 지니뮤직 크롤링하고 이름 순위 아티스트 가져오기/ 파이썬 공백 제거 strip(), [n:n] (0) | 2021.06.10 |
---|---|
[python] 파이썬으로 크롤링하는 법 / 영화페이지 제목 크롤링하는 법 친절 설명 (0) | 2021.06.10 |
[python] pymongo, robo3t 사용 기본 문법 insert/ find/ update/ delete (0) | 2021.06.10 |
[python] 크롤링으로 영화 제목 랭킹 별점 가져오기 (0) | 2021.06.10 |
[python] 크롤링 기본 뼈대 (0) | 2021.06.10 |