• HTMLParser学习笔记(一)


    转载 http://www.cnblogs.com/dlutxm/archive/2011/12/13/2286862.html  

    最近一直在学习搜索引擎的相关知识,在对于原始的HTML网页的处理是其中非常重要的一个环节,也就是所说的“去噪”,比如去掉相关的标签和不需要的JS代码等等,HTMLParser(http://htmlparser.sourceforge.net/)是一个对现有的HTML进行分析的快速实时的解析工具。它是一个开源的项目,通过它可以准确高效地对HTML文本中的格式、数据进行处理。利用它可以很容易地对网页的内容进行分析、过滤和抓取。它的主要功能分为以下几个部分:

          文本信息抽取:提取网页中的文字。

          链接提取:提取网页中的链接信息和锚文本。

          资源提取:网页中图片、声音的处理。

          链接检查:用于检查HTML中的链接是否有效。

          内容检查:可以用来过滤网页上一些令人不愉快的字词。

         HTMLParser最核心的模块是Parser类,这个类实际完成了对于HTML页面的分析工作,构造函数如下:

         public Parser ();     API链接地址:http://htmlparser.sourceforge.net/javadoc/index.html
         public Parser (Lexer lexer, ParserFeedback fb);
         public Parser (URLConnection connection, ParserFeedback fb) throws ParserException;
         public Parser (String resource, ParserFeedback feedback) throws ParserException;
         public Parser (String resource) throws ParserException;
         public Parser (Lexer lexer);
         public Parser (URLConnection connection) throws ParserException;

         我们通常使用的是通过一个URLConnection或者一个保存有网页内容的字符串来初始化Parser,或者使用静态函数来生成一个Parser对象。

         下面我们给出两个简单的初始化的例子。

     1.下面是通过传递保存有网页内容的字符串来初始化Parser和通过Parser静态函数来生成Parser对象

    import java.io.BufferedReader;
    import java.io.ByteArrayInputStream;
    import java.io.File;
    import java.io.FileInputStream;
    import java.io.FileNotFoundException;
    import java.io.FileOutputStream;
    import java.io.FileReader;
    import java.io.FileWriter;
    import java.io.IOException;
    import java.io.InputStreamReader;
    import java.io.UnsupportedEncodingException;
    import java.util.HashMap;
    import java.util.Map;
    import java.util.StringTokenizer;
    import java.util.regex.Matcher;
    import java.util.regex.Pattern;
     
    import javax.swing.plaf.metal.MetalFileChooserUI;
     
    import org.htmlparser.Node;
    import org.htmlparser.NodeFilter;
    import org.htmlparser.Parser;
    import org.htmlparser.filters.NodeClassFilter;
    import org.htmlparser.filters.OrFilter;
    import org.htmlparser.nodes.TextNode;
    import org.htmlparser.tags.JspTag;
    import org.htmlparser.tags.LinkTag;
    import org.htmlparser.tags.MetaTag;
    import org.htmlparser.tags.TableTag;
    import org.htmlparser.tags.TitleTag;
    import org.htmlparser.util.NodeList;
    import org.htmlparser.util.ParserException;
     
     
    public class t {
     
        /**
         * @param args
         * @throws IOException
         */
        public final static String testFilePath="C:"+File.separator+"glose - 博客园.htm";
        public final static String urlName="http://www.cnblogs.com/dlutxm/";
        public static String readFile(String fileName) throws IOException{           //读本地文件内容
            FileInputStream fin=new FileInputStream(fileName);
            InputStreamReader inReader=new InputStreamReader(fin,"utf-8");
            BufferedReader bReader=new BufferedReader(inReader);
            StringBuffer content=new StringBuffer();
            String line=null;
            while((line=bReader.readLine())!=null){
                content.append(line);
                content.append("\n");
            }
            bReader.close();
            inReader.close();
            fin.close();
            //System.out.println(content);
            return content.toString();
        }
        public static void parser(String content) throws ParserException{
            Parser parser=Parser.createParser(content, "utf-8");
         //Parser parser=new Parser(content);
            NodeList nodeList=null;
             
            //  注册特定标签的类  或者说某个特定的节点
            NodeFilter titleFilter=new NodeClassFilter(TitleTag.class);
            NodeFilter metaFilter=new NodeClassFilter(MetaTag.class);
            NodeFilter textFilter=new NodeClassFilter(TextNode.class);
            NodeFilter tableFilter=new NodeClassFilter(TableTag.class);
            NodeFilter linkFilter=new NodeClassFilter(LinkTag.class);
            NodeFilter jspFilter=new NodeClassFilter(JspTag.class);
             
             
            //OrFilter类可以得到其参数中设置的任何节点类型,节点之间是或的关系  具体实现方法为setPredicates()
            OrFilter lastFilter=new OrFilter();
            lastFilter.setPredicates(new NodeFilter[]{titleFilter,metaFilter,textFilter,tableFilter,linkFilter,jspFilter});
             
            nodeList=parser.parse(lastFilter);
             
            Node [] nodes=nodeList.toNodeArray();
            String line="";
            for(int i=0;i<nodes.length;i++){
                Node node=nodes[i];
                if(node instanceof TitleTag){   //得到网页的标题
                    TitleTag titlenode=(TitleTag)node;
                    line=titlenode.getTitle();
                    //System.out.println(line);
                }
                else if(node instanceof MetaTag) { //得到meta中的content内容,包括网页的关键字、编码、描述信息等。
                    MetaTag metaTag=(MetaTag)node;
                    line=metaTag.getAttribute("content"); 
                    //System.out.println(line);
                }
                 
                else if(node instanceof TextNode){  //得到文本内容
                    TextNode textNode=(TextNode)node;
                    line=textNode.getText();
                    //System.out.println(line);
                }
                else if(node instanceof TableTag){  
                    TableTag tableTag=(TableTag)node;
                    line=tableTag.toPlainTextString();   //得到表格的内容
                    //System.out.println(line);
                    String width=tableTag.getAttribute("width");
                    String height=tableTag.getAttribute("height");
                    //System.out.println(width);
                }
                else if(node instanceof LinkTag){    //得到网页中的链接和链接文本
                    LinkTag linknode=(LinkTag)node;
                    String linkText=linknode.getLinkText();
                    String link=linknode.getLink();
                     
                    System.out.println(linkText);
                    System.out.println(link);
                }
                else if(node instanceof JspTag){   //解析网页中的Javas,ASP等动态的代码
                    JspTag jspTag=(JspTag)node;
                    line=jspTag.toString();
                    System.out.println(line);
                }
                 
            }
                 
        }
        public static void main(String[] args) throws IOException, ParserException {
            // TODO Auto-generated method stub
            String content=readFile(testFilePath);
            parser(content);
        }
     
    }

      

    2.下面是通过一个URLConnection来初始化Parser

     

    import java.io.IOException;
    import java.net.HttpURLConnection;
    import java.net.MalformedURLException;
    import java.net.URL;
     
    import org.htmlparser.Node;
    import org.htmlparser.NodeFilter;
    import org.htmlparser.Parser;
    import org.htmlparser.filters.NodeClassFilter;
    import org.htmlparser.filters.OrFilter;
    import org.htmlparser.tags.TitleTag;
    import org.htmlparser.util.NodeList;
    import org.htmlparser.util.ParserException;
     
     
    public class urlTest {
     
        /**
         * @param args
         * @throws IOException
         * @throws MalformedURLException
         * @throws ParserException
         */
        public static void parser(String url) throws MalformedURLException, IOException, ParserException{
            HttpURLConnection urlConnection=(HttpURLConnection) (new URL(url)).openConnection();
            Parser parser=new Parser(urlConnection);
            NodeFilter titleFilter=new NodeClassFilter(TitleTag.class);
            NodeList nodeList=null;
            OrFilter lasFilter=new OrFilter();
            lasFilter.setPredicates(new NodeFilter[]{titleFilter});
            nodeList=parser.parse(lasFilter);
            Node []nodes=nodeList.toNodeArray();
            for(int i=0;i<nodes.length;i++){
                if(nodes[i] instanceof TitleTag){
                    TitleTag titleTag=(TitleTag)nodes[i];
                    String title=titleTag.getTitle();
                    System.out.println(title);
                }
            }
             
        }
        public static void main(String[] args) throws MalformedURLException, ParserException, IOException {
            // TODO Auto-generated method stub
            String url="http://www.baidu.com";
            parser(url);
        }
     
    }

     3.下面是对相关的Parser对象构造函数进行了很好的封装和测试。常用的构造Parser对象的方法有以下几种:

    import java.io.IOException;
    import java.net.HttpURLConnection;
    import java.net.MalformedURLException;
    import java.net.URL;
     
    import org.htmlparser.Node;
    import org.htmlparser.NodeFilter;
    import org.htmlparser.Parser;
    import org.htmlparser.filters.NodeClassFilter;
    import org.htmlparser.filters.OrFilter;
    import org.htmlparser.http.ConnectionManager;
    import org.htmlparser.lexer.Page;
    import org.htmlparser.tags.TitleTag;
    import org.htmlparser.util.NodeList;
    import org.htmlparser.util.ParserException;
     
     
    public class IteratorNode {
     
        /**
         * @param args
         */
        public static Parser getParserWithUrlStr(String urlStr,String encoding) throws ParserException{
            Parser parser=new Parser();
            parser.setURL(urlStr);
            parser.setEncoding(encoding);
            return parser;
        }
        public static Parser getParserWithUrlConn(String urlStr,String encoding) throws IOException, ParserException{
            URL url=new URL(urlStr);
            HttpURLConnection urlConnection=(HttpURLConnection) url.openConnection();
            Parser parser=new Parser(urlConnection);
            parser.setEncoding(encoding);
            return parser;
        }
        public static Parser getParserWithUrlConn2(String urlStr,String encoding) throws ParserException{
            ConnectionManager manager=Page.getConnectionManager();
            Parser parser=new Parser(manager.openConnection(urlStr));
            parser.setEncoding(encoding);
            return parser;
        }
        public static Parser createParser(String htmlContent,String encoding){   //读取本地文件
            Parser parser=Parser.createParser(htmlContent, encoding);
            return parser;
        }
        public static void main(String[] args) throws ParserException, IOException {
            // TODO Auto-generated method stub
            Parser parser1=getParserWithUrlStr("http://www.baidu.com", "utf-8");
            Parser parser2=getParserWithUrlConn("http://www.baidu.com", "utf-8");
            Parser parser=getParserWithUrlConn2("http://www.baidu.com", "utf-8");
            NodeFilter titleFilter=new NodeClassFilter(TitleTag.class);
            NodeList nodeList=null;
            OrFilter lasFilter=new OrFilter();
            lasFilter.setPredicates(new NodeFilter[]{titleFilter});
            nodeList=parser.parse(lasFilter);
            Node []nodes=nodeList.toNodeArray();
            for(int i=0;i<nodes.length;i++){
                if(nodes[i] instanceof TitleTag){
                    TitleTag titleTag=(TitleTag)nodes[i];
                    String title=titleTag.getTitle();
                    System.out.println(title);
                }
            }
             
        }
     
    }
  • 相关阅读:
    wince开发_摩托罗拉MC3100_打开条码设置
    【Scala类型系统】自身类型(self type)引用
    Scala 基础新手教程
    ActiveMQ消息队列的使用及应用
    nginx配置服务器负载均衡
    ActiveMQ_Linux安装
    js调试工具Console命令详解
    微信JS-SDK选择相册或拍照并上传PHP实现
    微信公众平台开发接口PHP SDK完整版
    微信JS接口汇总及使用详解
  • 原文地址:https://www.cnblogs.com/chenying99/p/2728685.html
Copyright © 2020-2023  润新知