Skip to content

Commit

Permalink
feat: add scraping logic for local council 113-168
Browse files Browse the repository at this point in the history
  • Loading branch information
keonly committed Oct 13, 2023
1 parent 215cc21 commit 7b5e189
Show file tree
Hide file tree
Showing 4 changed files with 805 additions and 35 deletions.
241 changes: 241 additions & 0 deletions scrap/local_councils/chungcheong.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,241 @@
from urllib.parse import urlparse

from scrap.utils.types import CouncilType, Councilor, ScrapResult, ScrapBasicArgument
from scrap.utils.requests import get_soup
from scrap.local_councils.basic import *


def scrap_124(
url="https://council.cheongju.go.kr/content/member/member.html",
args: ScrapBasicArgument = None,
) -> ScrapResult:
"""충청북도 청주시 페이지에서 의원 상세약력 스크랩
:param url: 의원 목록 사이트 url
:return: 의원들의 이름과 정당 데이터를 담은 ScrapResult 객체
"""
soup = get_soup(url, verify=False)
councilors: List[Councilor] = []

memcontent = soup.find("div", class_="memContent")

for profile in memcontent.find_all("li"):
name_tag = profile.find("dd", class_="name")
name = name_tag.get_text(strip=True) if name_tag else "이름 정보 없음"

party = "정당 정보 없음"
for tag in profile.find_all("dd"):
tag_text = tag.get_text(strip=True)
if "소속정당" in tag_text:
party = tag_text.split(":")[1].strip()
break

councilors.append(Councilor(name=name, party=party))

return ScrapResult(
council_id=str(124),
council_type=CouncilType.LOCAL_COUNCIL,
councilors=councilors,
)


def scrap_125(
url="https://council.chungju.go.kr/content/member/memberName.html",
args: ScrapBasicArgument = None,
) -> ScrapResult:
"""충청북도 충주시 페이지에서 의원 상세약력 스크랩
:param url: 의원 목록 사이트 url
:return: 의원들의 이름과 정당 데이터를 담은 ScrapResult 객체
"""
soup = get_soup(url, verify=False)
councilors: List[Councilor] = []

memcontent = soup.find("ul", class_="mlist")

for profile in memcontent.find_all("li"):
name_tag = profile.find("dd", class_="name")
name = name_tag.get_text(strip=True) if name_tag else "이름 정보 없음"

party = "정당 정보 없음"
for tag in profile.find_all("dd"):
if tag.span and "소속정당" in tag.span.get_text(strip=True):
party = tag.get_text(strip=True).split(":")[1].strip()
break

councilors.append(Councilor(name=name, party=party))

return ScrapResult(
council_id=str(125),
council_type=CouncilType.LOCAL_COUNCIL,
councilors=councilors,
)


def scrap_126(
url="https://www.jecheon.go.kr/council/lawmakerList.do?key=4393",
args: ScrapBasicArgument = None,
) -> ScrapResult:
"""충청북도 제천시 페이지에서 의원 상세약력 스크랩
:param url: 의원 목록 사이트 url
:return: 의원들의 이름과 정당 데이터를 담은 ScrapResult 객체
"""
soup = get_soup(url, verify=False)
councilors: List[Councilor] = []

party_list = soup.find("div", class_="tab_obj n2")
party_tags = party_list.find_all("h4")

for party_tag in party_tags:
party = party_tag.get_text(strip=True)

profile_wrapper = party_tag.find_next("div", class_="intro_council_list")

for profile in profile_wrapper.find_all("div", class_="intro_council_box"):
name_tag = profile.find("p", class_="name")
name = name_tag.get_text(strip=True) if name_tag else "이름 정보 없음"
councilors.append(Councilor(name=name, party=party))

return ScrapResult(
council_id=str(126),
council_type=CouncilType.LOCAL_COUNCIL,
councilors=councilors,
)


def scrap_132(
url="https://council.jincheon.go.kr/council/lawmakerList.do?key=70",
args: ScrapBasicArgument = None,
) -> ScrapResult:
"""충청북도 제천시 페이지에서 의원 상세약력 스크랩
:param url: 의원 목록 사이트 url
:return: 의원들의 이름과 정당 데이터를 담은 ScrapResult 객체
"""
soup = get_soup(url, verify=False)
councilors: List[Councilor] = []

party_list = soup.find("div", {"id": "tabs-2"})
party_tags = party_list.find_all("h3")

for party_tag in party_tags:
party = party_tag.get_text(strip=True)

profile_wrapper = party_tag.find_next("div", class_="member_profile")

for profile in profile_wrapper.find_all("li"):
name_tag = profile.find("h4", class_="h0")
if name_tag:
name = name_tag.get_text(strip=True).split()[0] # 김철수 의원 -> 김철수
councilors.append(Councilor(name=name, party=party))

return ScrapResult(
council_id=str(132),
council_type=CouncilType.LOCAL_COUNCIL,
councilors=councilors,
)


def scrap_134(
url="https://council.jp.go.kr/source/korean/member/active.html",
args: ScrapBasicArgument = None,
) -> ScrapResult:
"""충청북도 증평군 페이지에서 의원 상세약력 스크랩
:param url: 의원 목록 사이트 url
:return: 의원들의 이름과 정당 데이터를 담은 ScrapResult 객체
"""
soup = get_soup(url, verify=False, encoding="euc-kr")
councilors: List[Councilor] = []

profiles = soup.find_all("div", class_="active_list")

for profile in profiles:
name_tag = profile.find("span", class_="name")
name = name_tag.get_text(strip=True) if name_tag else "이름 정보 없음"

party = "정당 정보 없음"
ul_tags = profile.find("ul", class_="profile").find_all("li")
for tag in ul_tags:
if "소속정당" in tag.get_text():
party = tag.get_text().replace("소속정당 : ", "").strip()
break

councilors.append(Councilor(name=name, party=party))

return ScrapResult(
council_id=str(134),
council_type=CouncilType.LOCAL_COUNCIL,
councilors=councilors,
)


def scrap_140(
url="https://council.taean.go.kr/main/index.php?m_cd=11",
args: ScrapBasicArgument = None,
) -> ScrapResult:
"""충청남도 태안군 페이지에서 의원 상세약력 스크랩
:param url: 의원 목록 사이트 url
:return: 의원들의 이름과 정당 데이터를 담은 ScrapResult 객체
"""
soup = get_soup(url, verify=False)
councilors: List[Councilor] = []

member_list = soup.find("div", class_="member_list")

for profile in member_list.find_all("dl"):
name_tag = profile.find("strong")
name = name_tag.get_text(strip=True) if name_tag else "이름 정보 없음"

party_tag = profile.find("li", class_="jungdang")
party = party_tag.get_text(strip=True) if party_tag else "정당 정보 없음"

councilors.append(Councilor(name=name, party=party))

return ScrapResult(
council_id=str(140),
council_type=CouncilType.LOCAL_COUNCIL,
councilors=councilors,
)


def scrap_142(
url="https://www.nonsancl.go.kr/kr/member/active",
args: ScrapBasicArgument = None,
) -> ScrapResult:
"""충청남도 논산시 페이지에서 의원 상세약력 스크랩
:param url: 의원 목록 사이트 url
:return: 의원들의 이름과 정당 데이터를 담은 ScrapResult 객체
"""
base_url = "https://www.nonsancl.go.kr/kr/member/profile_popup?uid="
soup = get_soup(url)
councilors: list[Councilor] = []

for profile in soup.find_all("dl", class_="profile"):
name_tag = profile.find("em", class_="name").get_text(strip=True)
name = name_tag if name_tag else "이름 정보 없음"

data_uid = profile.find("a", class_="start")["data-uid"]
member_soup = get_soup(base_url + data_uid)

party_tag = member_soup.find("ul", class_="profile_list")
party = (
party_tag.select_one("li:contains('소속정당')")
.text.replace("소속정당:", "")
.strip()
)

councilors.append(Councilor(name=name, party=party))

return ScrapResult(
council_id=str(142),
council_type=CouncilType.LOCAL_COUNCIL.value,
councilors=councilors,
)


if __name__ == "__main__":
print(scrap_142())
Loading

0 comments on commit 7b5e189

Please sign in to comment.