Document类

一、类结构

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类

时间: 2024-10-24 02:11:01

Document类的相关文章

PHP至Document类操作 xml 文件

今天将项目上传到服务器后,打开项目发现报错 Error:undefined function appendChild()......,根据提示查看源代码,发现 new Document()->loadxml('xml文件路径'),xml文件加载失败,但是在我本地服务器是没有问题,所以我通过 file_get_contents()函数获取到了 xml文件,然后再使用 loadXML()加载,问题解决.

交叉引用的解决方法——类声明的应用

交叉引用的解决方法 什么是交叉引用? 什么是交叉引用?一言以蔽之,就是:A类中包含B类的对象,B类中包含A类的对象. 以一场景为例 我们先来看一个场景.假设有一个电子文档(Document).一个文档下有多个页(Page),每个页下有多个文本单元(TextUnit,表示文档内元素的基本单位),一个文档中的所有文本单元对象都有唯一的ID.这样每创建一个文本单元时都要为其设置一个唯一的ID,我们在Document类中就需要一个生成唯一ID的方法为所有的文本单元创建唯一标识.于是我们就会有下面的类关系

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

 1  Lucene卡发包结构分析 包名 功能 org.apache.lucene.analysis Analysis提供自带的各种Analyzer org.apache.lucene.collation 包含collationKeyFilter和collationKeyAnalyzer两个相同功能的类,将所有token转为CollationKey,与IndexableBinaryStringTools一起存为term org.apache.lucene.document Document包

六,WPF的Application类

Application.ShutdownMode属性:通过,只要有一个窗口还没有关闭,Application类就保持应用程序处于有效状态,如果这不是所期望的行为,就可以调整该属性. 应用程序事件 Application提供了为数不多的几个非常有用的事件,如下图所示: 有两种选择用于处理事件:在XAML中使用事件特性的方式关联事件处理程序,或重写相应的受保护方法,当重写应用程序方法时,推荐首先调用基类的实现,通常,基类的实现只是引发相应的应用程序事件. 初始界面(SplashScreen) WPF

MFC 之支持串行化的类

MFC中可以串行化的类必须满足以下条件 1 从CObject派生,或者间接派生 2 重写Serialize函数 3 使用DECLARE_SERIAL宏 4 定义不带参数的构造函数 5 在类的实现文件中用IMPLENT_SERIAL宏 在绘图保存的程序中,类CPaints作为保存的基本单元,它里面存储了绘图类型,起始点,终止点三个成员变量. 然后在绘图中每当绘制一幅图都会将CPaints作为保存对象,保存在View类的CObArray类型的变量中. 在文件保存中需要在Document类中保存Vie

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

一.IndexWriter详解 问题1:索引创建过程完成什么事? 分词.存储到反向索引中 1. 回顾Lucene架构图: 介绍我们编写的应用程序要完成数据的收集,再将数据以document的形式用lucene的索引API创建索引.存储. 这里重点要强调应用代码负责做什么,lucene负责做什么. 2. Lucene索引创建API 图示 通过该图介绍lucene创建索引的核心API:Document.IndexWriter Lucene中要索引的文档.数据记录以document表示,应用程序通过I

HTML Document

HTML Document 类 Visual Basic(声明) Public NotInheritable Class HtmlDocument Visual Basic(用法) Dim instance As HtmlDocument JScript public final class HtmlDocument HtmlDocument 为 Internet Explorer 的文档对象提供托管包装,该文档对象也称为 HTML 文档对象模型 (DOM).您可以通过 WebBrowser 控

Lucene 基础理论

1. 全文检索系统与Lucene简介 1.1 什么是全文检索与全文检索系统 全文检索是指计算机索引程序通过扫描文章中的每一个词,对每一个词建立一个索引,指明该词在文章中出现的次数和位置,当用户查询时,检索程序就根据事先建立的索引进行查找,并将查找的结果反馈给用户的检索方式.这个过程类似于通过字典中的检索字表查字的过程. 全文检索的方法主要分为按字检索和按词检索两种.按字检索是指对于文章中的每一个字都建立索引,检索时将词分解为字的组合.对于各种不同的语言而言,字有不同的含义,比如英文中字与词实际上

在C#中使用Spire.doc对word的操作总结

在C#中使用Spire.doc对word的操作总结 在最近的工程中我们要处理一些word文档.通过在网上的大量搜索,我发现大多数软件功能不是不完整就是有重复.极少数可以完全实现的word组件又要收费.功夫不负有心人,终于找到了可以满足我们需要的免费的C# word程序库.为了和其他的作比较,我在这里先做以下汇总.希望对大家有帮助. 如何得到? 这个免费版的word 组件可以在Codeplex下载到,你也可以从本文里直接下载msi文件.它还提供了一些源代码. Word操作汇总 1.