BeautifulSoup, selenium, ChromeDriverManager, WebdriverWait 라이브러리 등을 불러옵니다.
from bs4 import BeautifulSoup
import pandas as pd
from selenium import webdriver
from selenium.webdriver.chrome.service import Service
from webdriver_manager.chrome import ChromeDriverManager
from selenium.webdriver.support.ui import WebDriverWait
아래 코드를 통하여, Selenium 웹 드라이버를 실행하는 과정을 수행합니다.
# Selenium 웹 드라이버 실행
driver = webdriver.Chrome(service = service)
driver.get(url)
wait = WebDriverWait(driver, 10)
테이블 정보를 담는 데이터프레임을 생성합니다.
리스트 구조를 활용하여 for문을 돌면서 각 tr의 td 데이터를 담는 데이터프레임을 생성합니다.
아래와 같이 tr 안의 td에 들어있는 값들을 하나씩 리스트에 추가하는 코드를 작성합니다.
# 데이터를 저장할 빈 리스트 생성
data_rows = []
# table_contents의 각 tr 태그(행)에 대해 반복하면서 ,td 데이터를 컬럼에 담는다.
for tr in table_contents.find_all('tr'):
# 각 열에 해당하는 데이터 추출
data = []
for td in tr.find_all('td'):
text = td.get_text(strip=True)
# 열에 데이터를 추가
data.append(text)
# 데이터를 행으로 추가
data_rows.append(data)
위에서와 마찬가지로 for문 구조를 작성하는데, 이번에는 td.find('img') 코드를 추가하여,
위에서 만든 데이터프레임에 빈 칸이 생기는 경우가 없도록 할 것입니다.
# table_contents의 각 tr 태그(행)에 대해 반복하면서, td 데이터를 컬럼에 담아준다.
for tr in table_contents.find_all('tr'):
# 각 열에 해당하는 데이터 추출
data = []
for td in tr.find_all('td'):
# td 안에 있는 im 태그가 있는지 확인, alt 속성 추출
img_tag = td.find('img')
# img_tag가 존재하면
if img_tag:
text = img_tag.get("alt", "")
else:
text = td.get_text(strip=True)
# 열에 데이터를 추가
data.append(text)
# data, 즉 방금까지 td 태그들이 쌓인 data 리스트에 url도 하나 더 추가
data.append(url)
# 데이터를 행으로 추가
data_rows.append(data)
"if img_tag" 조건문을 추가하고 img 태그가 있는 경우에는 "img_tag.get("alt", "")" 과정이 수행되도록 합니다.
그 외의 경우에는 위에서 진행한 대로 "td.get_text(strip=True)" 과정이 진행되도록 합니다.
KBS 뉴스탭에서 전체 카테고리를 선택하고 일자별 뉴스 항목에 접근합니다. 먼저, 한 항목을 선택하여 페이지로 이동합니다. F12 버튼을 통해 개발자 모드에 접근하면 각 element들에 대한 자세한 정보를 얻을 수 있으며 이는 뒤에서 바로 진행할 것입니다.
하나의 요소에서 정보를 수집하는 것으로 시작하여, 추후에 여러 뉴스에서 정보를 수집하는 실습을 진행할 것입니다.
개발자 모드 F12를 통한 요소 분석
타이틀 부분은 h4로 싸여 있고 class는 "headline-title"임을 확인할 수 있습니다. 본문 부분은 "detail-body font-size"라는 클래스로 되어있음을 확인할 수 있습니다. 개발자 모드에서 접근한 뒤, 화살표 버튼을 통해 내가 원하는 요소에 대한 정보를 쉽게 얻을 수 있습니다. < br > 태그는 엔터 기능에 해당합니다.
라이브러리 호출
기본적인 라이브러리들을 호출하기 위하여 아래 코드를 실행합니다.
import requests
from bs4 import BeautifulSoup
위에서 호출한 requests 라이브러리를 통하여 url의 텍스트 정보를 가져올 수 있습니다.
# 홈 디렉토리 확인
from pathlib import Path
print(Path.home())
# 작업 디렉토리 확인
from pathlib import Path
print(Path.cwd())
# 디렉토리 내용 확인
from pathlib import Path
files = Path.cwd().glob('*')
for f in files:
print(f)
기본적인 파일 읽고 쓰기
파일 쓰기
# 파일 열기
f = open('MyFile.txt', 'w')
# 파일 쓰기
f.write('안녕하세요?\n')
# 파일 닫기
f.close()
디렉토리 만들기
# 디렉토리 만들기
Path('Files').mkdir(exist_ok=True)
파일 열기, 쓰기, 닫기
# 파일 열기
f = open('Files/MyFile.txt', 'w')
# 파일 쓰기
f.write('모두들 안녕하세요?\n')
# 파일 닫기
f.close()
파일 읽기
# 파일 열기
f = open('MyFile.txt', 'r')
# 내용 읽기
print(f.read())
# 파일 닫기
f.close()
경로 지정해서 읽기
# 파일 열기
f = open('Files/MyFile.txt', 'r')
# 내용 읽기
print(f.read())
# 파일 닫기
f.close()
파일 내용 추가
# 파일 열기
f = open('MyFile.txt', 'a')
# 내용 추가
f.write('만나서 반갑습니다!')
# 파일 닫기
f.close()
x 모드, 같은 파일이 있으면 오류 발생
# 파일 열기
f = open('MyFile.txt', 'x')
# 내용 쓰기
f.write('만나서 반갑습니다!')
# 파일 닫기
f.close()
# 오류 핸들링
try:
f = open('MyFile.txt', 'x')
f.write('만나서 반갑습니다!')
f.close()
except FileExistsError: # 이미 파일이 있으면
print('같은 이름의 파일이 있습니다.')
else: # 그렇지 않으면
print('파일 쓰기 성공했습니다.')
finally: # 마무리
print('수고하셨습니다.')
파일 다루기 실습
python 파일 만들기
# 파일 열기
f = open('Python.txt', 'w')
내용 입력
# 내용 쓰기
f.write('''<파이썬과 나>
시인: 홍길동''')
# 파일 닫기
f.close()
내용 추가
# 파일 열기
f = open('Python.txt', 'a')
# 내용 추가
f.write('''
어느날
파이썬이 나에게 왔다.
많이 낯설었다.
지금은 나와 하나가 되었다.
파이썬이 나고,
내가 파이썬이다.''')
# 파일 닫기
f.close()
ㆍ f = open('Python.txt', 'a')에서 'a'는 파일을 "추가 모드(append mode)"로 열기 위한 파일 모드
writelines()
# 파일 여러 줄 쓰기
hello = ['안녕하세요?\n', '만나서 반갑습니다!\n', '우리 사이좋게 잘 지내요.\n']
f = open('MyFile.txt', 'w')
f.writelines(hello)
f.close()
내용 확인
# 파일 읽기
f = open('MyFile.txt', 'r')
print(f.read())
f.close()
readlines()
# 파일 한 번에 읽기
f = open('MyFile.txt', 'r')
result = f.readlines()
f.close()
# 내용 확인
print(result)
# 반복문으로 한 행씩 표시
for txt in result:
print(txt, end='')
readline()
ㆍ 행 단위로 읽기
# 파일 읽기
f = open('MyFile.txt', 'r')
# 내용 읽기
print(f.readline(), end='')
print(f.readline(), end='')
print(f.readline(), end='')
# 파일 닫기
f.close()
ㆍ 반복문을 이용해 모든 행 읽기
# 파일 읽기
f = open('MyFile.txt', 'r')
result = f.readline()
# 반복문으로 한 행씩 읽어 표시
while result:
print(result, end='')
result = f.readline()
# 파일 닫기
f.close()