Skip to content

Commit

Permalink
feat :: 충청북도 영덕군 보건소 크롤링 완성
Browse files Browse the repository at this point in the history
  • Loading branch information
s1hyun2 committed Nov 26, 2024
1 parent d465aa3 commit 87705c8
Showing 1 changed file with 134 additions and 0 deletions.
134 changes: 134 additions & 0 deletions Gyeongsangbuk-do/Yeongdeok-gun.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,134 @@
import re
import os
import sys
import time
import requests
import urllib.parse
from bs4 import BeautifulSoup, Comment
from selenium import webdriver
from selenium.webdriver.chrome.service import Service as ChromeService
from webdriver_manager.chrome import ChromeDriverManager
from selenium.webdriver.chrome.options import Options

sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))

from config import babya_server

chrome_options = Options()
chrome_options.add_experimental_option("detach", True)
driver = webdriver.Chrome(service=ChromeService(ChromeDriverManager().install()), options=chrome_options)

try:
region = "111120"
current_list = list()
result_data = []

site_url = requests.get(f"{babya_server}/policy/site", params={"region": region})
response_data = site_url.json()
base_url = response_data["data"]["policySiteUrl"]
format_url = base_url.split("/?page_id=")[0]

collected_site_data = requests.get(f"{babya_server}/policy/catalog", params={"site": base_url})
collected_list = [item["pageId"] for item in collected_site_data.json()["data"]]

url = f"{format_url}/?p=1690"
driver.get(url)
time.sleep(2)
soup = BeautifulSoup(driver.page_source, 'html.parser')

for i in soup.select("#dc_jqaccordion_widget-59-item > ul.menu > li > a"):
if i.text == "보건사업안내":
parent_element = i.find_parent("li")
for j in parent_element.select("ul.sub-menu > li.menu-item > a"):
if j.text == "모자보건" or j.text == "출산장려사업":
id_item = j.get("href").split("?p=")[1]
current_list.append(id_item)


page_list = set(current_list) - set(collected_list)

for page_id in page_list:
page_url = f"{format_url}/?p={page_id}"
driver.get(page_url)
time.sleep(2)
soup = BeautifulSoup(driver.page_source, 'html.parser')

data_dict = {
"title": None,
"content": None,
"editDate": None,
"pageId": None,
"site": None,
"page": None
}

styles = ["<style> .rtbs_content { display: block !important; } </style>"]

for comment in soup.find_all(string=lambda text: isinstance(text, Comment)):
comment.extract()

for meta in soup.select("html > head > meta"):
if meta.get("charset"):
styles.append(str(meta))

for link in soup.select("html > head > link"):
if link.get("rel")[0] == "stylesheet":
link_url = link.get("href")
link["href"] = urllib.parse.urljoin(base_url, link_url)
styles.append(str(link))

for title in soup.select("div.RT_ttl > h2"):
data_dict["title"] = title.get_text()

for content in soup.select("div.post-content"):
for tag in content.find_all("div", class_="rtbs_menu"):
tag.extract()

for img in content.find_all('img'):
img_url = img.get("src")
if img_url:
img["src"] = urllib.parse.urljoin(base_url, img_url)

for a in content.find_all("a", href=True):
file_url = a['href']
a['href'] = urllib.parse.urljoin(base_url, file_url)

styles_str = "".join(styles)
content_str = re.sub(r'[\s\u00A0-\u00FF]+', " ", str(content))

head_content = f"<head>{styles_str}</head>"
body_content = f"<body><div id='content'>{content_str}</div></body>"

html_content = f"<!DOCTYPE html><html>{head_content}{body_content}</html>"
data_dict["content"] = html_content

# 최근수정일 없음

data_dict["pageId"] = page_id
data_dict["site"] = base_url
data_dict["page"] = page_url

if all(data_dict[key] is not None for key in ["title", "content"]):
result_data.append(data_dict)


if (len(result_data) > 0):
print(f"크롤링한 페이지 개수: [{len(result_data)}]")
policy = requests.post(f"{babya_server}/policy", json=result_data)
print(policy.status_code)
print(policy.text)

else:
print("아직 새로운 정책이 업데이트 되지 않았습니다.")

except Exception as e:
print(f"Error: {e}")
driver.close()
sys.exit()

finally:
driver.close()
sys.exit()

while True:
pass

0 comments on commit 87705c8

Please sign in to comment.