3週目コード開発ログ(3-10~3-14)
5136 ワード
データベース#データベース# MongoDB=データベースが稼働していますが、私の目には は見えません. robo 3 T=MongDB可視化 データベースを使用する理由は、格納されているデータの検索と使用です.データベースの「プログラムの作成」会社によって方法が異なります.
✦ RDBMS(SQL)
行または列の外観を持つ指定したセルにデータを格納するのと同じです.50万個のデータの場合、真ん中に突然1つの列を追加するのは難しい.しかしながら、データは固定されているため、データの整合性または/分析は非常に容易である可能性がある.
ex)MS-SQL、My-SQL等
✦ No-SQL
ディック形式でデータを格納するDB.したがって、データごとに同じ値を指定する必要はありません.フリーフォームのデータ・ロードに不利な一貫性が欠けている可能性があります.
ex) MongoDB
␣
▼pymongoでDBを操作するタイプ:insert、find、update、delete mongodyはディックシャーナによって蓄積された である.
✦ Insert
Web Crapping結果の保存
1.映画祭目録『マトリックス』の採点を獲得
完了コード 「ハッカー帝国」の採点と同じ映画名を獲得した 完了コード マトリックス映画スコア0
完了コード
✦ RDBMS(SQL)
行または列の外観を持つ指定したセルにデータを格納するのと同じです.50万個のデータの場合、真ん中に突然1つの列を追加するのは難しい.しかしながら、データは固定されているため、データの整合性または/分析は非常に容易である可能性がある.
ex)MS-SQL、My-SQL等
✦ No-SQL
ディック形式でデータを格納するDB.したがって、データごとに同じ値を指定する必要はありません.フリーフォームのデータ・ロードに不利な一貫性が欠けている可能性があります.
ex) MongoDB
␣
▼pymongoでDBを操作する
✦ Insert
from pymongo import MongoClient
→ pymongo를 쓰겠습니다.
client = MongoClient('localhost', 27017)
→ 내 컴퓨터에서 지금 돌아가고 있는 mongoDB에 접속할 겁니다.
db = client.dbsparta
→ dbsparta라고 하는 DB 이름으로 접속할 겁니다.
doc = {'name':'bobby','age':21}
db.users.insert_one(doc)
→ db 안에 users라는 collection에 insert 해라
✽ 기본 형태
from pymongo import MongoClient
client = MongoClient('localhost', 27017)
db = client.dbsparta
doc = {'name':'bobby','age':21}
db.users.insert_one(doc)
✦ Findfrom pymongo import MongoClient
client = MongoClient('localhost', 27017)
db = client.dbsparta
same_ages = list(db.users.find({'age':21},{'_id':False}))
→ {'_id':False} id값은 제외라는 뜻
same_ages = list(db.users.find({},{'_id':False}))
→ id값을 제외하고 모두({}) 가져와라
for person in same_ages:
print(same_ages)
✦ Find_oneuser = db.users.find_one({'name':'bobby'})
→ name bobby만 갖고 와라
user = db.users.find_one({'name':'bobby'},{'_id':False})
→ id를 제외하고 name bobby만 갖고 와라
print(user['age'])
→ user에 age만 출력해라
✦ Update_onedb.users.update_one({'name':'bobby'},{'$set':{'age':19}})
→ name이 bobby인 것을 찾아서 age를 19로 바꿔라
✦ Delete_onedb.users.delete_one({'name':'bobby'})
→ name이 bobby인 것을 찾아서 delete해라
␣Web Crapping結果の保存
import requests
from bs4 import BeautifulSoup
✽ MongoDB 기본 코드 추가
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']
star = tr.select_one('td.point').text
doc = { → 딕셔너리를 만듬
'rank':rank,
'title':title,
'star':star
}
db.movies.insert_one(doc)
☑️ Quiz1.映画祭目録『マトリックス』の採点を獲得
from pymongo import MongoClient
client = MongoClient('localhost', 27017)
db = client.dbsparta
movie = db.movies.find_one({'title':'매트릭스'})
print(movie['star'])
from pymongo import MongoClient
client = MongoClient('localhost', 27017)
db = client.dbsparta
target_movie = db.movies.find_one({'title':'매트릭스'})
target_star = target_movie['star']
movies = list(db.movies.find({'star':target_star}))
for movie in movies:
print(movie['title'])
from pymongo import MongoClient
client = MongoClient('localhost', 27017)
db = client.dbsparta
db.movies.update_one({'title':'매트릭스'},{'$set':{'star':0}})
Reference
この問題について(3週目コード開発ログ(3-10~3-14)), 我々は、より多くの情報をここで見つけました https://velog.io/@dudgus899/3주차-코딩-개발-일지-3-10-3-14テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol