91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java如何實現基于模板的網頁結構化信息精準抽取組件HtmlExtractor

發布時間:2021-10-12 16:00:30 來源:億速云 閱讀:108 作者:柒染 欄目:云計算

今天就跟大家聊聊有關Java如何實現基于模板的網頁結構化信息精準抽取組件HtmlExtractor,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

HtmlExtractor是一個Java實現的基于模板的網頁結構化信息精準抽取組件,本身并不包含爬蟲功能,但可被爬蟲或其他程序調用以便更精準地對網頁結構化信息進行抽取。

HtmlExtractor是為大規模分布式環境設計的,采用主從架構,主節點負責維護抽取規則,從節點向主節點請求抽取規則,當抽取規則發生變化,主節點主動通知從節點,從而能實現抽取規則變化之后的實時動態生效。

如何使用?

HtmlExtractor由2個子項目構成,html-extractor和html-extractor-web。
html-extractor實現了數據抽取邏輯,是從節點,html-extractor-web提供web界面來維護抽取規則,是主節點。
html-extractor是一個jar包,可通過maven引用:
<dependency>
    <groupId>org.apdplat</groupId>
    <artifactId>html-extractor</artifactId>
    <version>1.0</version>
</dependency>
  html-extractor-web是一個war包,需要部署到Servlet/Jsp容器上。

單機集中式使用方法:

//1、構造抽取規則

List<UrlPattern> urlPatterns = new ArrayList<>();
//1.1、構造URL模式
UrlPattern urlPattern = new UrlPattern();
urlPattern.setUrlPattern("http://money.163.com/\\d{2}/\\d{4}/\\d{2}/[0-9A-Z]{16}.html");
//1.2、構造HTML模板
HtmlTemplate htmlTemplate = new HtmlTemplate();
htmlTemplate.setTemplateName("網易財經頻道");
htmlTemplate.setTableName("finance");
//1.3、將URL模式和HTML模板建立關聯
urlPattern.addHtmlTemplate(htmlTemplate);
//1.4、構造CSS路徑
CssPath cssPath = new CssPath();
cssPath.setCssPath("h2");
cssPath.setFieldName("title");
cssPath.setFieldDescription("標題");
//1.5、將CSS路徑和模板建立關聯
htmlTemplate.addCssPath(cssPath);
//1.6、構造CSS路徑
cssPath = new CssPath();
cssPath.setCssPath("div#endText");
cssPath.setFieldName("content");
cssPath.setFieldDescription("正文");
//1.7、將CSS路徑和模板建立關聯
htmlTemplate.addCssPath(cssPath);
//可象上面那樣構造多個URLURL模式
urlPatterns.add(urlPattern);

//2、獲取抽取規則對象
ExtractRegular extractRegular = ExtractRegular.getInstance(urlPatterns);
//注意:可通過如下3個方法動態地改變抽取規則
//extractRegular.addUrlPatterns(urlPatterns);
//extractRegular.addUrlPattern(urlPattern);
//extractRegular.removeUrlPattern(urlPattern.getUrlPattern());

//3、獲取HTML抽取工具
HtmlExtractor htmlExtractor = HtmlExtractor.getInstance(extractRegular);

//4、抽取網頁
String url = "http://money.163.com/08/1219/16/4THR2TMP002533QK.html";
List<ExtractResult> extractResults = htmlExtractor.extract(url, "gb2312");

//5、輸出結果
int i = 1;
for (ExtractResult extractResult : extractResults) {
    System.out.println((i++) + "、網頁 " + extractResult.getUrl() + " 的抽取結果");
    for(ExtractResultItem extractResultItem : extractResult.getExtractResultItems()){
        System.out.print("\t"+extractResultItem.getField()+" = "+extractResultItem.getValue());              
    }
    System.out.println("\tdescription = "+extractResult.getDescription());
    System.out.println("\tkeywords = "+extractResult.getKeywords());
}

 

多機分布式使用方法:

1、運行主節點,負責維護抽取規則:
  將子項目html-extractor-web打成War包然后部署到Tomcat。
2、獲取一個HtmlExtractor的實例(從節點),示例代碼如下:
String allExtractRegularUrl = "http://localhost:8080/HtmlExtractorServer/api/all_extract_regular.jsp";
String redisHost = "localhost";
int redisPort = 6379;
HtmlExtractor htmlExtractor = HtmlExtractor.getInstance(allExtractRegularUrl, redisHost, redisPort);
3、抽取信息,示例代碼如下:
String url = "http://money.163.com/08/1219/16/4THR2TMP002533QK.html";
List<ExtractResult> extractResults = htmlExtractor.extract(url, "gb2312");

int i = 1;
for (ExtractResult extractResult : extractResults) {
    System.out.println((i++) + "、網頁 " + extractResult.getUrl() + " 的抽取結果");
    for(ExtractResultItem extractResultItem : extractResult.getExtractResultItems()){
        System.out.print("\t"+extractResultItem.getField()+" = "+extractResultItem.getValue());              
    }
    System.out.println("\tdescription = "+extractResult.getDescription());
    System.out.println("\tkeywords = "+extractResult.getKeywords());
}

看完上述內容,你們對Java如何實現基于模板的網頁結構化信息精準抽取組件HtmlExtractor有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

德昌县| 贵南县| 无锡市| 洪湖市| 丹江口市| 台北县| 大同市| 额济纳旗| 疏勒县| 临潭县| 乳山市| 凉城县| 枣阳市| 吴忠市| 莱阳市| 卓尼县| 辽阳县| 曲靖市| 旅游| 姜堰市| 廉江市| 什邡市| 威信县| 得荣县| 福泉市| 灵山县| 沐川县| 孝昌县| 龙海市| 濉溪县| 四子王旗| 木兰县| 泰兴市| 鄂温| 沙坪坝区| 台江县| 芦山县| 芮城县| 沿河| 长葛市| 绵阳市|