Development/Python

python, mongoDb

evagrim 2022. 7. 22. 12:50

웹 개발용 python 라이브러리

 

 

 

requests

python에서 ajax처럼 데이터를 받기 위한 라이브러리

 

사용 예)

1
2
3
4
5
6
7
8
9
import requests # requests 라이브러리 설치 필요
 
= requests.get('URL')
rjson = r.json()
 
gus = rjson['RealtimeCityAir']['row']
 
for gu in gus:
    print(gu['MSRSTE_NM'], gu['IDEX_MVL'])
cs

 

 

 

bs4 > BeautifulSoup

html 긁어올 때 사용

 

사용 예)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
import requests
from bs4 import BeautifulSoup
 
# URL을 읽어서 HTML를 받아오고,
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.naver?sel=pnt&date=20210829',headers=headers)
 
# HTML을 BeautifulSoup이라는 라이브러리를 활용해 검색하기 용이한 상태로 만듦
soup = BeautifulSoup(data.text, 'html.parser')
 
# select를 이용해서, tr들을 불러오기
movies = soup.select('#old_content > table > tbody > tr')
 
# movies (tr들) 의 반복문을 돌리기
for movie in movies:
    # movie 안에 a 가 있으면,
    a_tag = movie.select_one('td.title > div > a')
    if a_tag is not None:
        # a의 text를 찍어본다.
        print (a_tag.text)
cs

선택자 사용 법)

1
2
3
4
5
6
7
8
9
10
11
12
13
# 선택자를 사용하는 방법 (copy selector)
soup.select('태그명')
soup.select('.클래스명')
soup.select('#아이디명')
 
soup.select('상위태그명 > 하위태그명 > 하위태그명')
soup.select('상위태그명.클래스명 > 하위태그명.클래스명')
 
# 태그와 속성값으로 찾는 방법
soup.select('태그명[속성="값"]')
 
# 한 개만 가져오고 싶은 경우
soup.select_one('위와 동일')
cs

태그 안의 텍스트를 찍고 싶을 땐 → 태그.text

태그 안의 속성을 찍고 싶을 땐 → 태그['속성']

 

 

 

pymongo > MongoClient

mongodb 제어

 

사용 예)

1
2
3
4
5
6
7
8
9
10
from pymongo import MongoClient
client = MongoClient('여기에 URL 입력')
db = client.mydb
 
doc = {
    'name':'bob',
    'age':27
}
 
db.users.insert_one(doc)
cs

사용 예2)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# 저장 - 예시
doc = {'name':'bobby','age':21}
db.users.insert_one(doc)
 
# 한 개 찾기 - 예시
user = db.users.find_one({'name':'bobby'})
 
# 여러개 찾기 - 예시 ( _id 값은 제외하고 출력)
all_users = list(db.users.find({},{'_id':False}))
 
# 바꾸기 - 예시
db.users.update_one({'name':'bobby'},{'$set':{'age':19}})
 
# 지우기 - 예시
db.users.delete_one({'name':'bobby'})
cs

 

 

 

dnspython

python용 dnstoolkit

https://www.dnspython.org/examples/