如何用JAVA从HTML源代码中提取有用的文本信息? 15

比如在网页上有一段需要的信息,请问怎样用java编程将其提取出来并保存?... 比如在网页上有一段需要的信息,请问怎样用java编程将其提取出来并保存? 展开
 我来答
德缘哥哥
推荐于2017-12-15 · TA获得超过217个赞
知道小有建树答主
回答量:193
采纳率:100%
帮助的人:66.7万
展开全部
可以使用java API中的URL抓取流,也可以使用Apache的HttpClient等多种方法,最终得到的就是字符串咯,得到字符串就好办了,使用正则匹配,将匹配的保存起来就可以了
追问
正则表达式吗?这个不是特别理解,能具体讲一下吗,假如我需要提取的信息有几段,有数字也有中文是分开匹配吗?
追答

如将连接中的流读取出来方法:

/**
     * 将网页上的数据流转成字符串
     * 
     * @param url
     * @return
     * @throws IOError 
     */
    public String getSourceFromURL(String url) throws IOException {
        URL u=new URL(url);
        InputStream in=u.openStream();
        StringBuilder sb=new StringBuilder();
        byte[] buff=new byte[1024];
        int len;
        while((len=in.read(buff))!=-1){
            //此处使用UTF-8编码,如果遇到像新浪这样的网站编码不是UTF-8的,就会乱,
            //此处我就不过细处理了
            sb.append(new String(buff,0,len,"UTF-8"));
            
        }
        in.close();
        return String.valueOf(sb);
    }

获得网页中的所有数据后,便可以使用正则表达式匹配了,这不得不说要正则表达式灵活运用才方能不用代码进行各种处理了,我的正则表达式都有一段时间没有,又陌生了:

此处我就随便写一个获取标题的正则吧,不过没有做什么就近匹配,如果页面有多个能匹配到的标签,那么可能会匹配不到想要的


推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式