본문 바로가기
SportsViz

[스포츠 데이터] 역대 국가대표 축구 A매치 득점 데이터 수집 및 시각화 어렵지 않습니다!

by 강쌤 의 ViziBiziBusy 2021. 11. 17.

2021년 축구 국가대표 A매치 경기가 모두 마무리 되었습니다.

 

2021년까지 역대 남자 축구 국가대표 A팀의 데이터를 수집 및 시각화 해보겠습니다.
웹 페이지에서 특정한 영역에 있는 데이터를 xpath를 활용해서 스크래핑해 보겠습니다.

 

xpath?

XML Path LanguageXML 문서에서 특정 위치에 있는 값을 찾을 때(경로 지정) 사용하는 언어입니다.

 

상위 폴더에서 하위 폴더로 구조화된 요소들을 찾아보겠습니다. 여기에서는 구글 시트에서 IMPORTXML 함수를 활용해서 필요한 xpath 영역을 가져오는 실습을 하겠습니다.

데이터는 축구협회(KFA)의 데이터를 수집하겠습니다.

 

1.     구글 시트 (Google Sheets)에서 새로운 스프레드시트를 오픈합니다.

 

2.     새로운 시트의 이름을 역대 대한민국 축구 A대표팀 득점 순위로 입력합니다.

 

3.     하단의 시트 이름을 남자 A대표팀으로 변경합니다.

 

4.     (다음부터는 가급적 IE 대신 크롬이나 파이어폭스 또는 웨일 브라우저 등을 사용하실 것을 추천 드립니다.) 여기에서 KFA 홈페이지의 아카이브’ > 기록실 > 각종 기록실 페이지로 이동합니다. 이 곳의 URLhttps://www.kfa.or.kr/archive/etc_record.php입니다.

 

5.     여기 메뉴에서 스크로을 아래로 옮긴 다음 남자A매치(개인)_A매치 개인 최다 득점 순위(2021.11.17 기준)' 클릭합니다. 그러면 1위 차범근부터 역대 득점 기준 순위가 테이블 형태로 나오는 것을 볼 수 있습니다.

출처 - KFA 홈페이지

 

6.     차범근에 우클릭 후 맨 아래에 검사를 선택합니다. 그럼 여러분들의 브라우저 우측(또는 하단)에 개발자 도구 화면이 나타나는데, 이 때 좌측 상단에 있는 마우스 포인터로 스크래핑하려는 영역에 마우스 오버하면 개발자 도구에 해당 부분이 음영 처리되는 것을 볼 수 있습니다. 여기에서는 각 선수별 Row 기준 데이터를 불러오기 위해서는 <tr> 영역내 ‘1’, ‘차범근’, ’58, ‘1976 올림픽 예선 2득점 포함. 2000FIFA 승인 기록은 55까지 모두 수집해보겠습니다.

 

개발자 도구에서 xpath를 확인해보자

 

 

7.     ‘1위 차범근영역을 가져오기 위해 구글 시트의 남자 A대표팀시트의 A2 셀에 다음과 같이 입력합니다.

=importxml("https://www.kfa.or.kr/archive/etc_record.php","//tr[14]/td/table/tbody/tr[1]")

 

8.     그리고 A1 셀은 순위’ B1셀은 선수’, C1셀은 득점’, D1셀은 비고’로 씁니다. 결과는 다음과 같습니다.

 

9.     1위뿐만 아니라 전체 영역의 데이터를 모두 수집하고 싶다면 A2 셀을 다음과 같이 변경합니다.

=importxml("https://www.kfa.or.kr/archive/etc_record.php","//tr[14]/td/table/tbody/tr[*]")

 

10.  간단한 시각화 결과물은 다음과 같습니다. 축구공 이미지를 형상화해서 표현해봤습니다.

카타르 월드컵 최종예선 이라크 전에서 골을 기록한 손흥민 선수는 A매치 30번째 골을 기록하며 역대 6위이자, 역대 Top 10 선수 중 유일한 현역 선수입니다. 

 

 

참고로 xpath를 활용한 데이터 수집 같은 경우에는 해당 웹 페이지를 운영하는 곳에서 페이지 개편 등이 있는 경우 이후에는 동일하게 실습이 안될 수도 있으니, 해당 영역을 어떤 식으로 스크래핑할 수 있을지 다양한 사례를 테스트 해보시기 바랍니다

 

데이터 수집 및 시각화 어렵지 않습니다!

댓글