一、类结构

org.jsoup.nodes
Class Document

java.lang.Object

org.jsoup.nodes.Node

org.jsoup.nodes.Element

org.jsoup.nodes.Document

All Implemented Interfaces:

Cloneable

--------------------------------------------------------------------------------

public class Document

extends

Element

一个HTML文档

二、方法

Constructor Summary
 
Document(String baseUri)
构造函数:根据baseUri创建一个空白HTML文档
 
 
Method Summary
 
Element
 body()
获取HTML文档的body内容
 
Document
 clone()
创建一份Document的完整拷贝
 
Element
 createElement(String tagName)
创建一个tagName节点
 
static Document
 createShell(String baseUri)
创建一个空白的整体HTML框架
 
Element
 head()
获取Document的head值
 
String
 nodeName()
获取一个节点的节点名
 
Document
 normalise()
使document正常化
 
String
 outerHtml()
获取节点的HTML
 
Document.OutputSettings
 outputSettings()
          Get the document's current output settings.
 
Document
 outputSettings(Document.OutputSettings outputSettings)
          Set the document's output settings.
 
Document.QuirksMode
 quirksMode()

Document
 quirksMode(Document.QuirksMode quirksMode)

Element
 text(String text)
获取节点或者Document的text值
 
String
 title()

获取Document的title值
 
void
 title(String title)
设置Document的title值

三、实例

[java] view plaincopyprint?
import org.jsoup.Jsoup; 
import org.jsoup.nodes.Document; 
import org.jsoup.nodes.Element; 
  
public class JsoupDocument { 
    private static Document doc; 
    private static Document shell; 
    public static void main(String[] args) { 
       try { 
           doc =  Jsoup.connect("http://www.baidu.com").get(); 
           //System.out.println(doc);  
           //Body();   
           //Clone();         
           //CreateElement();           
           //CreateShell();  
           //Head();  
           //NodeName();  
           //OuterHtml();  
           //Text("你好");  
           //Text();  
           //Title();  
           Title("伊诺克Eliot"); 
       } catch (Exception e) { 
           // TODO Auto-generatedcatch block  
           e.printStackTrace(); 
       } 
    } 
    //获取body  
    private static void Body(){ 
       System.out.println(doc.body()); 
    } 
    //克隆Document  
    private static void Clone(){ 
       Document clone = doc.clone(); 
       System.out.println(clone); 
    } 
    //创建一个节点,例如:<div></div>  
    private static void CreateElement(){ 
       Element e = doc.createElement("div"); 
       System.out.println(e); 
    } 
    //创建一个整体框架  
    /*
     输出:
     <html>
     <head></head>
     <body></body>
     </html>  
     */ 
    private static void CreateShell(){ 
       shell = Document.createShell("http://www.baidu.com"); 
       System.out.println(shell); 
    } 
    //获取Head  
    /*
     * 输出:
     * <head>
        <meta http-equiv="content-type"content="text/html;charset=utf-8" />
        <title>百度一下,你就知道</title>
        <style>html,body{height:100%}.....省略.... </style>
       
<script>functionh(obj){obj.style.behavior='url(#default#homepage)';vara
= obj.setHomePage('http://www.baidu.com/');}</script>
       </head>
     * */ 
    private static void Head(){ 
       Element e = doc.head(); 
       System.out.println(e); 
    } 
    //获取节点名  
    private static void NodeName(){ 
       String name = doc.body().nodeName(); 
       System.out.println(name); 
       name = doc.body().getElementById("content").nodeName(); 
       System.out.println(name); 
       name = doc.body().getElementById("content").getElementById("u").nodeName(); 
       System.out.println(name); 
    } 
    //获取节点的html  
    /*
     * 输出:
     * <divid="u">
        <a href="http://www.baidu.com/gaoji/preferences.html"name="tj_setting">搜索设置</a>|
        <a
href="https://passport.baidu.com/v2/?login&tpl=mn&u=http%3A%2F%2Fwww.baidu.com%2F"
name="tj_login" id="lb"onclick="return false;">登录</a> <a
href="https://passport.baidu.com/v2/?reg&regType=1&tpl=mn&u=http%3A%2F%2Fwww.baidu.com%2F"
target="_blank"name="tj_reg" class="reg">注册</a>
       </div>
     * */ 
    private static void OuterHtml(){ 
       String html = doc.body().getElementById("content").getElementById("u").outerHtml(); 
       //Element html =doc.body().getElementById("content").getElementById("u");  
       System.out.println(html); 
    } 
    //设置节点或者Document的text值  
    //设置Document的text值时,body中的节点将全部被删除  
    private static void Text(String text){ 
       //设置节点的text  
       Element e = doc.body().getElementById("content").getElementById("u").select("a").get(0).text(text); 
       System.out.println(e); 
       //设置Document的text值  
       doc.text(text); 
       System.out.println(doc); 
    } 
    //获取节点或者Document的text值  
    private static void Text(){ 
       String text = doc.body().getElementById("content").getElementById("u").select("a").get(0).text(); 
       System.out.println(text); 
    } 
    //设置Document的title值  
    private static void Title(String title){ 
       doc.title(title); 
       System.out.println(doc); 
    } 
    //获取Document的title值  
    private static void Title(){ 
       String text = doc.title(); 
       System.out.println(text); 
    } 
}

import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
 
public class JsoupDocument {
    private static Document doc;
    private static Document shell;
    public static void main(String[] args) {
       try {
           doc =  Jsoup.connect("http://www.baidu.com").get();
           //System.out.println(doc);
           //Body();
           //Clone();      
           //CreateElement();        
           //CreateShell();
           //Head();
           //NodeName();
           //OuterHtml();
           //Text("你好");
           //Text();
           //Title();
           Title("伊诺克Eliot");
       } catch (Exception e) {
           // TODO Auto-generatedcatch block
           e.printStackTrace();
       }
    }
    //获取body
    private static void Body(){
       System.out.println(doc.body());
    }
    //克隆Document
    private static void Clone(){
       Document clone = doc.clone();
       System.out.println(clone);
    }
    //创建一个节点,例如:<div></div>
    private static void CreateElement(){
       Element e = doc.createElement("div");
       System.out.println(e);
    }
    //创建一个整体框架
    /*
     输出:
     <html>
     <head></head>
     <body></body>
     </html> 
     */
    private static void CreateShell(){
       shell = Document.createShell("http://www.baidu.com");
       System.out.println(shell);
    }
    //获取Head
    /*
     * 输出:
     * <head>
        <meta http-equiv="content-type"content="text/html;charset=utf-8" />
        <title>百度一下,你就知道</title>
        <style>html,body{height:100%}.....省略.... </style>
       
<script>functionh(obj){obj.style.behavior='url(#default#homepage)';vara
= obj.setHomePage('http://www.baidu.com/');}</script>
       </head>
     * */
    private static void Head(){
       Element e = doc.head();
       System.out.println(e);
    }
    //获取节点名
    private static void NodeName(){
       String name = doc.body().nodeName();
       System.out.println(name);
       name = doc.body().getElementById("content").nodeName();
       System.out.println(name);
       name = doc.body().getElementById("content").getElementById("u").nodeName();
       System.out.println(name);
    }
    //获取节点的html
    /*
     * 输出:
     * <divid="u">
        <a href="http://www.baidu.com/gaoji/preferences.html"name="tj_setting">搜索设置</a>|
        <a
href="https://passport.baidu.com/v2/?login&tpl=mn&u=http%3A%2F%2Fwww.baidu.com%2F"
name="tj_login" id="lb"onclick="return false;">登录</a> <a
href="https://passport.baidu.com/v2/?reg&regType=1&tpl=mn&u=http%3A%2F%2Fwww.baidu.com%2F"
target="_blank"name="tj_reg" class="reg">注册</a>
       </div>
     * */
    private static void OuterHtml(){
       String html = doc.body().getElementById("content").getElementById("u").outerHtml();
       //Element html =doc.body().getElementById("content").getElementById("u");
       System.out.println(html);
    }
    //设置节点或者Document的text值
    //设置Document的text值时,body中的节点将全部被删除
    private static void Text(String text){
       //设置节点的text
       Element e = doc.body().getElementById("content").getElementById("u").select("a").get(0).text(text);
       System.out.println(e);
       //设置Document的text值
       doc.text(text);
       System.out.println(doc);
    }
    //获取节点或者Document的text值
    private static void Text(){
       String text = doc.body().getElementById("content").getElementById("u").select("a").get(0).text();
       System.out.println(text);
    }
    //设置Document的title值
    private static void Title(String title){
       doc.title(title);
       System.out.println(doc);
    }
    //获取Document的title值
    private static void Title(){
       String text = doc.title();
       System.out.println(text);
    }
}
四、总结

Document类主要是一些有关HTML文档的方法,包括获得HTML文档的body、头Head、整体框架Shell、标题Title、
Text(其实就是body的内容)、HTML文档的拷贝,函数作用的主体大多数为Document。可以更改Title、Text以及HTML文档中某
个节点的text值。

Document类的更多相关文章

  1. jsoup的Document类

    一.简介 Document是一个装载html的文档类,它是jsoup一个非常重要的类.类声明:public class Document extends Element .Document是Node间 ...

  2. PHP至Document类操作 xml 文件

    今天将项目上传到服务器后,打开项目发现报错 Error:undefined function appendChild()......, 根据提示查看源代码,发现 new Document()-> ...

  3. 浅析mongoEngine的document对象

    引言: from mongoengine import * connect('local')class Test(Document): name=StringField(max_length=32) ...

  4. 六,WPF的Application类

    Application.ShutdownMode属性:通过,只要有一个窗口还没有关闭,Application类就保持应用程序处于有效状态,如果这不是所期望的行为,就可以调整该属性. 应用程序事件 Ap ...

  5. 3.Lucene3.x API分析,Director 索引操作目录,Document,分词器

     1  Lucene卡发包结构分析 包名 功能 org.apache.lucene.analysis Analysis提供自带的各种Analyzer org.apache.lucene.colla ...

  6. Lucene系列五:Lucene索引详解(IndexWriter详解、Document详解、索引更新)

    一.IndexWriter详解 问题1:索引创建过程完成什么事? 分词.存储到反向索引中 1. 回顾Lucene架构图: 介绍我们编写的应用程序要完成数据的收集,再将数据以document的形式用lu ...

  7. java---解析XML文件,通过反射动态将XML内容封装到一个类中

    本博客讲的XML解析,使用的是dom4j. 首先建立一个maven项目,在dom.xml中引入相应的dom4j的版本.作者下载的是热度很高的1.6.1版本.maven的使用在这里不做详细讲解. 引入成 ...

  8. 11.Bean2Document-BEAN转document

    1. package com.glodon.gspm.adapter.plugin.common; import com.glodon.cloudt.tenancy.context.TenantCon ...

  9. 【WPF学习】第二十七章 Application类的任务

    上一章介绍了有关WPF应用程序中使用Application对象的方式,接下来看一下如何使用Application对象来处理一些更普通的情况,接下俩介绍如何初始化界面.如何处理命名行参数.如何处理支付窗 ...

随机推荐

  1. 【PHP】常用的PHP正则表达式收集整理

    匹配中文字符的正则表达式: [\u4e00-\u9fa5]评注:匹配中文还真是个头疼的事,有了这个表达式就好办了 匹配双字节字符(包括汉字在内):[^\x00-\xff]评注:可以用来计算字符串的长度 ...

  2. 如何使用pyinstaller打包32位的exe

    说明:原来安装的python为64位,故安装的pyinstaller和打包后的exe都为64位.而64位的exe文件在32位的win7操作系统下是无法执行的,显示不兼容.网上查询发现,简单(可能不方便 ...

  3. python函数调用顺序、高阶函数、嵌套函数、闭包详解

    一:函数调用顺序:其他高级语言类似,Python 不允许在函数未声明之前,对其进行引用或者调用错误示范: def foo(): print 'in the foo' bar() foo() 报错: i ...

  4. Tomcat 在 Linux 下的自动启动脚本

    很多服务都需要设置为开机自启动.将下面代码复制到 /etc/rc.d/init.d/tomcat ,然后执行 chkconfig –add tomcat chkconfig tomcat on 就可以 ...

  5. Python 信号处理 signal 模块

    Table of Contents 1. signal模块简介 1.1. signal简单示例 1.2. signal说明 1.2.1. 基本的信号名 1.2.2. 常用信号处理函数 2. signa ...

  6. Maven 用Eclipse创建web项目后报错的解决方式

    1.maven中创建web项目后jsp可能会报错,因为其没有相关的依赖(包),和自带的动态网页项目创建不一样.所以在配置文件中要添加相关的依赖,比如servlet的 2.项目右键-maven-upda ...

  7. cf975d Ghosts

    ref #include <algorithm> #include <iostream> #include <cstdio> #include <map> ...

  8. uoj206 [APIO2016]最大差分

    ref #include "gap.h" #include <iostream> #include <cstdio> using namespace std ...

  9. luogu3224 [HNOI2012]永无乡

    线段树合并好写好调,隔壁老王的treap+启发式合并难写难调 #include <iostream> #include <cstdio> using namespace std ...

  10. 12 JVM 垃圾回收(下)

    Java 虚拟机的堆划分 Java 虚拟机将堆划分为新生代和老年代.其中新生代又被划分为 Eden 区,以及两个大小相同的 Survivor 区. 默认情况下,Java 虚拟机采取一种动态分配的策略, ...