一、引入jsoup的jar包:http://jsoup.org/download

  补充:http://jsoup.org/apidocs/   Jsoup API    可以了解更详细的内容

二、Jsoup将html字符串解析成Document结构

  1. public void testJsoupHtml(){
  2. String html="<table><tr><td>名称</td><td>价格(元/本)</td><td>描述</td></tr><tr><td>《雾都的孤儿》</td><td>33.4</td><td>叙述雾都的孤儿</td></tr></table>";
  3. Document doc = Jsoup.parse(html);
  4. System.out.println(doc.childNodeSize());
  5. }

Jsoup.parse(String str)说明:该解析器能够尽最大可能从你提供的HTML文档来创见一个干净的解析结果,无论HTML的格式是否完整。比如它可以处理:

  1、没有关闭的标签 (比如: <p>Lorem <p>Ipsum parses to <p>Lorem</p> <p>Ipsum</p>)
  2、隐式标签 (比如. 它可以自动将 <td>Table data</td>包装成<table><tr><td>?)
  3、创建可靠的文档结构(html标签包含head 和 body,在head只出现恰当的元素)

    补充说明:文档的对象模型简述:

      1、文档由多个Elements和TextNodes组成 (以及其它辅助nodes).
      2、其继承结构如下:Document继承Element继承Node. TextNode继承 Node.
      3、一个Element包含一个子节点集合,并拥有一个父Element。他们还提供了一个唯一的子元素过滤列表。

三、Jsoup通过URL解析html文档   获得Document对象

  具体代码如下:

  1. public void testJsoupUrl() throws IOException{
  2. String url="http://ntbedi04:11080/edi/task/allTask";
  3. Document doc=Jsoup.connect(url).get();
  4. String title=doc.title();
  5. System.out.println("文档的名称:"+title);
  6. }

  connect(String url)创建一个新的Collection对象,然后通过get()获得Document对象。

  connect()还有一些属性可以满足特殊的需求:

  1. public void testJsoupUrlPost() throws IOException{
  2. String url="";
  3. Document doc = Jsoup.connect(url)
  4. .data("query", "Java") //post请求的参数
  5. .userAgent("Mozilla") //请求代理
  6. .cookie("auth", "token")//cookie
  7. .timeout() //请求时间的设置
  8. .post();
  9. System.out.println(doc.title());
  10. }

三、Jsoup解析本地文件html文件

  1. public void testJsouploc() throws IOException{
  2. File htmlf=new File("C:/Users/Administrator/Desktop/choujiang.html");
  3. Document doc=Jsoup.parse(htmlf, "UTF-8");
  4. System.out.println(doc.title());
  5. }

对于相对路径中的文件,可以用parse(File in,String charsetName,String baseUrl)

  baseUri 参数用于解决文件中URLs是相对路径的问题。如果不需要可以传入一个空的字符串。
  另外还有一个方法parse(File in, String charsetName) ,它使用文件的路径做为 baseUri。 这个方法适用于如果被解析文件位于网站的本地文件系统,且相关链接也指向该文件系统。

四、Jsoup中Document对象的操作

Elements这个对象提供了一系列类似于DOM的方法来查找元素,抽取并处理其中的数据。具体如下:
 查找元素
  getElementById(String id)
  getElementsByTag(String tag)
  getElementsByClass(String className)
  getElementsByAttribute(String key) (and related methods)
  Element siblings: siblingElements(), firstElementSibling(), lastElementSibling();nextElementSibling(), previousElementSibling()
  Graph: parent(), children(), child(int index)

元素数据
  attr(String key)获取属性attr(String key, String value)设置属性
  attributes()获取所有属性
  id(), className() and classNames()
  text()获取文本内容text(String value) 设置文本内容
  html()获取元素内HTMLhtml(String value)设置元素内的HTML内容
  outerHtml()获取元素外HTML内容
  data()获取数据内容(例如:script和style标签)
  tag() and tagName()

操作HTML和文本
  append(String html), prepend(String html)
  appendText(String text), prependText(String text)
  appendElement(String tagName), prependElement(String tagName)
  html(String value)

简单实例:

  1. public void testJsoupHtml(){
  2. String html="<table><tr><td>名称</td><td>价格(元/本)</td><td>描述</td></tr><tr><td>《雾都的孤儿》</td><td>33.4</td><td>叙述雾都的孤儿</td></tr></table>";
  3. Document doc = Jsoup.parse(html);
  4. Elements tables=doc.getElementsByTag("table");
  5. Elements tdlist=tables.get().getElementsByTag("td");
        //输出单元格中的内容
  6. for (Element str : tdlist) {
  7. System.out.println(str.text());
  8. }
  9. }

特别之处:获得某个值或对象

  可以使用Element.select(String selector) 和 Elements.select(String selector) 方法实现:

  1. Selector选择器概述
  2. tagname: 通过标签查找元素,比如:a
  3. ns|tag: 通过标签在命名空间查找元素,比如:可以用 fb|name 语法来查找 <fb:name> 元素
  4. #id: 通过ID查找元素,比如:#logo
  5. .class: 通过class名称查找元素,比如:.masthead
  6. [attribute]: 利用属性查找元素,比如:[href]
  7. [^attr]: 利用属性名前缀来查找元素,比如:可以用[^data-] 来查找带有HTML5 Dataset属性的元素
  8. [attr=value]: 利用属性值来查找元素,比如:[width=]
  9. [attr^=value], [attr$=value], [attr*=value]: 利用匹配属性值开头、结尾或包含属性值来查找元素,比如:[href*=/path/]
  10. [attr~=regex]: 利用属性值匹配正则表达式来查找元素,比如: img[src~=(?i)\.(png|jpe?g)]
  11. *: 这个符号将匹配所有元素

Selector选择器组合使用

  1. el#id: 元素+ID,比如: div#logo
  2. el.class: 元素+class,比如: div.masthead
  3. el[attr]: 元素+class,比如: a[href]
  4. 任意组合,比如:a[href].highlight
  5. ancestor child: 查找某个元素下子元素,比如:可以用.body p 查找在"body"元素下的所有p元素
  6. parent > child: 查找某个父元素下的直接子元素,比如:可以用div.content > p 查找 p 元素,也可以用body > * 查找body标签下所有直接子元素
  7. siblingA + siblingB: 查找在A元素之前第一个同级元素B,比如:div.head + div
  8. siblingA ~ siblingX: 查找A元素之前的同级X元素,比如:h1 ~ p
  9. el, el, el:多个选择器组合,查找匹配任一选择器的唯一元素,例如:div.masthead, div.logo

伪选择器selectors

  1. :lt(n): 查找哪些元素的同级索引值(它的位置在DOM树中是相对于它的父节点)小于n,比如:td:lt() 表示小于三列的元素
  2. :gt(n):查找哪些元素的同级索引值大于n,比如: div p:gt()表示哪些div中有包含2个以上的p元素
  3. :eq(n): 查找哪些元素的同级索引值与n相等,比如:form input:eq()表示包含一个input标签的Form元素
  4. :has(seletor): 查找匹配选择器包含元素的元素,比如:div:has(p)表示哪些div包含了p元素
  5. :not(selector): 查找与选择器不匹配的元素,比如: div:not(.logo) 表示不包含 class=logo 元素的所有 div 列表
  6. :contains(text): 查找包含给定文本的元素,搜索不区分大不写,比如: p:contains(jsoup)
  7. :containsOwn(text): 查找直接包含给定文本的元素
  8. :matches(regex): 查找哪些元素的文本匹配指定的正则表达式,比如:div:matches((?i)login)
  9. :matchesOwn(regex): 查找自身包含文本匹配指定正则表达式的元素

Jsoup解析HTML、加载文档等实例的更多相关文章

  1. Jsoup解析Html中文文档

    jsoup 简介Java 程序在解析 HTML 文档时,相信大家都接触过 htmlparser 这个开源项目,我曾经在 IBM DW 上发表过两篇关于 htmlparser 的文章,分别是:从 HTM ...

  2. iOS 应用中加载文档pdf/word/txt

    一.加载PDF文档:应用内打开文档.手机中其他应用打开文档 Demo 首先拖入一个文档pdf.word.txt,打开不同的文档知识 文件名字.类型修改即可 #import "ReadView ...

  3. 获取当前iframe动态加载文档的href

    Insus.NET想实现一个功能,一个旧的站点A,它有两个网页logon.aspx和Default.aspx(登录成功能访问).由于某些原因,需另建一个新站点B,这个新站点B也有两个网页B_Index ...

  4. Jsoup解析Xml{详解}

    1:  概述 * 代码: //2.1获取student.xml的path String path = JsoupDemo1.class.getClassLoader().getResource(&qu ...

  5. jsoup解析HTML及简单实例

    jsoup 中文参考文献    http://www.open-open.com/jsoup/ 本文将利用jsoup,简单实现网络抓取的功能,并给出一个小实例,该实例效果为:获取作者本人在博客园写的所 ...

  6. Java解析XML文档(简单实例)——dom解析xml

      一.前言 用Java解析XML文档,最常用的有两种方法:使用基于事件的XML简单API(Simple API for XML)称为SAX和基于树和节点的文档对象模型(Document Object ...

  7. json-lib-2.4-jdk15.jar所需全部JAR包.rar java jsoup解析开彩网api接口json数据实例

    json-lib-2.4-jdk15.jar所需全部JAR包.rar  java jsoup解析开彩网api接口json数据实例 json-lib-2.4-jdk15.jar所需全部JAR包.rar  ...

  8. jsoup Cookbook(中文版)-Jsoup解析HTML

    jsoup Cookbook(中文版) 入门 1.      解析和遍历一个html文档 如何解析一个HTML文档: String html = "<html><head& ...

  9. Android中利用jsoup解析html页面

    学习jsoup :jsoup学习网站 Android 中使用: 添加依赖 implementation 'org.jsoup:jsoup:1.10.1' 直接上代码: package com.load ...

随机推荐

  1. Excel和XML文件导入

    using System;using System.Collections;using System.Collections.Generic;using System.Configuration;us ...

  2. Opencl API解释(一)

    首先注明:我用的AMD的opencl,它有很多sample代码,结合代码来解释这些API Opencl 常用的API 汇总总结: 信息查询函数 1. cl_int clGetDeviceInfo(cl ...

  3. RHEL6彻底禁用ip6的方法

    一.vi  /etc/modprobe.d/disable-ipv6.conf(名字随便起)(RHEL6.0之后没有了/etc/modprobe.conf这个文件) 输入:install ipv6 / ...

  4. 《Differential Equations with Boundary-Value Problems》-chaper2-一阶线性方程

    学习微分方程中,一个很常见的疑惑就是,我们所熟悉的非齐次微分方程的通解是对应齐次方程的通解加特解,但是更为重要的是,我们需要知道这句话是怎么得来的. 我们探讨一个未知问题的一般思路是将其不断的与已知已 ...

  5. python编写的自动获取代理IP列表的爬虫-chinaboywg-ChinaUnix博客

    python编写的自动获取代理IP列表的爬虫-chinaboywg-ChinaUnix博客 undefined Python多线程抓取代理服务器 | Linux运维笔记 undefined java如 ...

  6. 为什么用 Java:一个 Python 程序员告诉你

    这篇文章专门给程序员写的,普通读者慎入.原作者:Kevin Sookocheff 译者:Celia Zhen,原文点击文末链接. 每当我告诉别人我一直在用Java工作时,大家的反应都是: “纳尼!Ja ...

  7. Yii学习系列:Yii视频讲义——前篇(转)

    1.yii的网址 http://www.yiiframework.com/ yii官方网址 http://www.yiichina.com/ yii中文社区 2.bootstrap的网址 http:/ ...

  8. 最小生成树之算法记录【prime算法+Kruskal算法】【模板】

    首先说一下什么是树: 1.只含一个根节点 2.任意两个节点之间只能有一条或者没有线相连 3.任意两个节点之间都可以通过别的节点间接相连 4.除了根节点没一个节点都只有唯一的一个父节点 5.也有可能是空 ...

  9. Quartz定时任务学习(五)触发器

    顾名思义,Trigger(触发器)的责任就是触发一个 Job 去执行.当用 Scheduler 注册一个 Job 的时候要创建一个 Trigger 与这个 Job 相关联.Quartz 提供了四种类型 ...

  10. win8笔记本无法搜索wifi信号找不到WLAN该 wifi共享特别注意的服务

    WlansvcWLAN AutoConfigWLANSVC 服务提供配置.发现.连接.断开与 IEEE 802.11 标准定义的无线局域网(WLAN)的连接所需的逻辑.它还包含将计算机变成软件访问点的 ...