효율적인 Java 크롤러 실습: 웹 데이터 크롤링 기술 공유
Java 크롤러 실습: 웹 페이지 데이터를 효율적으로 크롤링하는 방법
소개:
인터넷의 급속한 발전으로 인해 수많은 웹 페이지에 귀중한 데이터가 대량으로 저장됩니다. 이 데이터를 얻으려면 각 웹 페이지에 수동으로 액세스하여 정보를 하나씩 추출해야 하는 경우가 많으며 이는 의심할 여지 없이 지루하고 시간이 많이 걸리는 작업입니다. 이 문제를 해결하기 위해 사람들은 다양한 크롤러 도구를 개발했으며 그중 Java 크롤러가 가장 일반적으로 사용되는 것 중 하나입니다. 이 기사에서는 독자들이 Java를 사용하여 효율적인 웹 크롤러를 작성하는 방법을 이해하고 특정 코드 예제를 통해 실습을 보여줄 것입니다.
1. 크롤러의 기본 원리
웹 크롤러의 기본 원리는 브라우저를 시뮬레이션하여 HTTP 요청을 보낸 후 웹 페이지를 구문 분석하고 필요한 데이터를 추출하는 것입니다. 작업 프로세스는 대략 다음 단계로 나뉩니다.
- HTTP 요청 보내기: HttpURLConnection, HttpClient 등과 같은 Java의 네트워크 프로그래밍 라이브러리를 사용하여 HTTP 요청을 구성하고 대상 웹 페이지로 보냅니다.
- 웹 페이지 구문 분석: 웹 페이지 구조에 따라 Jsoup, XPath 등과 같은 적절한 구문 분석 라이브러리를 사용하여 HTML, XML 또는 JSON 형식의 웹 페이지를 구문 분석하고 필요한 데이터를 추출합니다.
- 데이터 처리 및 저장: 추출된 데이터를 정리, 필터링 등 처리한 후 후속 사용을 위해 데이터베이스, 파일 또는 메모리에 저장합니다.
2. 크롤러 개발 환경 생성
Java 크롤러 개발을 시작하려면 해당 환경을 구축해야 합니다. 먼저 JDK(Java Development Kit)와 Eclipse, IntelliJ IDEA 등 Java IDE(통합 개발 환경)가 설치되어 있는지 확인하세요. 그런 다음 HttpClient, Jsoup 등과 같은 필수 네트워크 프로그래밍 라이브러리를 프로젝트에 도입합니다.
3. 실습: Douban 영화 순위 데이터 가져오기
크롤러 개발 프로세스를 연습하기 위해 Douban 영화 순위 데이터를 예로 선택했습니다. 우리의 목표는 영화 이름, 평점, 리뷰어 수를 추출하는 것입니다.
- HTTP 요청 보내기
먼저 웹 페이지의 콘텐츠를 가져오기 위해 Java의 네트워크 프로그래밍 라이브러리를 사용하여 HTTP 요청을 보내야 합니다. 다음은 HttpClient 라이브러리를 사용하여 GET 요청을 보내는 샘플 코드입니다.
import org.apache.http.HttpEntity; import org.apache.http.client.methods.CloseableHttpResponse; import org.apache.http.client.methods.HttpGet; import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.HttpClients; import org.apache.http.util.EntityUtils; public class HttpClientExample { public static void main(String[] args) { CloseableHttpClient httpClient = HttpClients.createDefault(); HttpGet httpGet = new HttpGet("https://movie.douban.com/top250"); try (CloseableHttpResponse response = httpClient.execute(httpGet)){ HttpEntity entity = response.getEntity(); String result = EntityUtils.toString(entity); System.out.println(result); } catch (Exception e) { e.printStackTrace(); } } }
- 웹 페이지 구문 분석
HTTP 요청을 보내 Douban 영화 순위의 웹 콘텐츠를 얻었습니다. 다음으로, 필요한 데이터를 추출하기 위해 구문 분석 라이브러리를 사용해야 합니다. 다음은 Jsoup 라이브러리를 사용하여 HTML 페이지를 구문 분석하기 위한 샘플 코드입니다.
import org.jsoup.Jsoup; import org.jsoup.nodes.Document; import org.jsoup.nodes.Element; import org.jsoup.select.Elements; public class JsoupExample { public static void main(String[] args) { try { Document document = Jsoup.connect("https://movie.douban.com/top250").get(); Elements elements = document.select("ol.grid_view li"); for (Element element : elements) { String title = element.select(".title").text(); String rating = element.select(".rating_num").text(); String votes = element.select(".star span:nth-child(4)").text(); System.out.println("电影名称:" + title); System.out.println("评分:" + rating); System.out.println("评价人数:" + votes); System.out.println("-------------------------"); } } catch (Exception e) { e.printStackTrace(); } } }
- 데이터 처리 및 저장
실제 애플리케이션에서는 추출된 데이터를 추가로 처리하고 저장해야 할 수도 있습니다. 예를 들어, 나중에 사용할 수 있도록 데이터를 데이터베이스에 저장할 수 있습니다. 다음은 MySQL 데이터베이스를 사용하여 데이터를 저장하는 샘플 코드입니다.
import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; public class DataProcessingExample { public static void main(String[] args) { String jdbcUrl = "jdbc:mysql://localhost:3306/spider"; String username = "root"; String password = "password"; try (Connection conn = DriverManager.getConnection(jdbcUrl, username, password)) { String sql = "INSERT INTO movie (title, rating, votes) VALUES (?, ?, ?)"; PreparedStatement statement = conn.prepareStatement(sql); // 假设从网页中获取到了以下数据 String title = "肖申克的救赎"; String rating = "9.7"; String votes = "2404447"; statement.setString(1, title); statement.setString(2, rating); statement.setString(3, votes); int rowsAffected = statement.executeUpdate(); System.out.println("插入了 " + rowsAffected + " 条数据"); } catch (SQLException e) { e.printStackTrace(); } } }
IV. 요약
이 기사에서는 Java 크롤러의 기본 원리를 소개하고 특정 코드 예제를 통해 Java를 사용하여 효율적인 웹 크롤러를 작성하는 방법을 보여줍니다. 이러한 기본 지식을 학습함으로써 독자는 실제 요구에 따라 보다 복잡하고 유연한 크롤러 프로그램을 개발할 수 있습니다. 실제 적용에서는 법적 분쟁을 피하기 위해 크롤러의 합법적인 사용에 주의를 기울이고 웹사이트의 개인 정보 보호 정책과 서비스 약관을 존중해야 합니다. 이 기사가 독자들이 Java 크롤러를 학습하고 적용하는 데 도움이 되기를 바랍니다.
위 내용은 효율적인 Java 크롤러 실습: 웹 데이터 크롤링 기술 공유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Java의 난수 생성기 안내. 여기서는 예제를 통해 Java의 함수와 예제를 통해 두 가지 다른 생성기에 대해 설명합니다.

Java의 Weka 가이드. 여기에서는 소개, weka java 사용 방법, 플랫폼 유형 및 장점을 예제와 함께 설명합니다.

Java의 Smith Number 가이드. 여기서는 정의, Java에서 스미스 번호를 확인하는 방법에 대해 논의합니다. 코드 구현의 예.

이 기사에서는 가장 많이 묻는 Java Spring 면접 질문과 자세한 답변을 보관했습니다. 그래야 면접에 합격할 수 있습니다.

Java 8은 스트림 API를 소개하여 데이터 컬렉션을 처리하는 강력하고 표현적인 방법을 제공합니다. 그러나 스트림을 사용할 때 일반적인 질문은 다음과 같은 것입니다. 기존 루프는 조기 중단 또는 반환을 허용하지만 스트림의 Foreach 메소드는이 방법을 직접 지원하지 않습니다. 이 기사는 이유를 설명하고 스트림 처리 시스템에서 조기 종료를 구현하기위한 대체 방법을 탐색합니다. 추가 읽기 : Java Stream API 개선 스트림 foreach를 이해하십시오 Foreach 메소드는 스트림의 각 요소에서 하나의 작업을 수행하는 터미널 작동입니다. 디자인 의도입니다

Java의 TimeStamp to Date 안내. 여기서는 소개와 예제와 함께 Java에서 타임스탬프를 날짜로 변환하는 방법에 대해서도 설명합니다.

Java는 초보자와 숙련된 개발자 모두가 배울 수 있는 인기 있는 프로그래밍 언어입니다. 이 튜토리얼은 기본 개념부터 시작하여 고급 주제를 통해 진행됩니다. Java Development Kit를 설치한 후 간단한 "Hello, World!" 프로그램을 작성하여 프로그래밍을 연습할 수 있습니다. 코드를 이해한 후 명령 프롬프트를 사용하여 프로그램을 컴파일하고 실행하면 "Hello, World!"가 콘솔에 출력됩니다. Java를 배우면 프로그래밍 여정이 시작되고, 숙달이 깊어짐에 따라 더 복잡한 애플리케이션을 만들 수 있습니다.
