亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

零基礎(chǔ)寫Java知乎爬蟲之將抓取的內(nèi)容存儲到本地

 更新時間:2014年11月07日 11:19:37   投稿:hebedich  
上一回我們說到了如何把知乎的某些內(nèi)容爬取出來,那么這一回我們就說說怎么把這些內(nèi)容存儲到本地吧。

說到Java的本地存儲,肯定使用IO流進(jìn)行操作。
首先,我們需要一個創(chuàng)建文件的函數(shù)createNewFile:

復(fù)制代碼 代碼如下:

public static boolean createNewFile(String filePath) { 
        boolean isSuccess = true; 
        // 如有則將"\\"轉(zhuǎn)為"/",沒有則不產(chǎn)生任何變化 
        String filePathTurn = filePath.replaceAll("\\\\", "/"); 
        // 先過濾掉文件名 
        int index = filePathTurn.lastIndexOf("/"); 
        String dir = filePathTurn.substring(0, index); 
        // 再創(chuàng)建文件夾 
        File fileDir = new File(dir); 
        isSuccess = fileDir.mkdirs(); 
        // 創(chuàng)建文件 
        File file = new File(filePathTurn); 
        try { 
            isSuccess = file.createNewFile(); 
        } catch (IOException e) { 
            isSuccess = false; 
            e.printStackTrace(); 
        } 
        return isSuccess; 
    } 

然后,我們需要一個寫入文件的函數(shù):

復(fù)制代碼 代碼如下:

public static boolean writeIntoFile(String content, String filePath, 
            boolean isAppend) { 
        boolean isSuccess = true; 
        // 先過濾掉文件名 
        int index = filePath.lastIndexOf("/"); 
        String dir = filePath.substring(0, index); 
        // 創(chuàng)建除文件的路徑 
        File fileDir = new File(dir); 
        fileDir.mkdirs(); 
        // 再創(chuàng)建路徑下的文件 
        File file = null; 
        try { 
            file = new File(filePath); 
            file.createNewFile(); 
        } catch (IOException e) { 
            isSuccess = false; 
            e.printStackTrace(); 
        } 
        // 寫入文件 
        FileWriter fileWriter = null; 
        try { 
            fileWriter = new FileWriter(file, isAppend); 
            fileWriter.write(content); 
            fileWriter.flush(); 
        } catch (IOException e) { 
            isSuccess = false; 
            e.printStackTrace(); 
        } finally { 
            try { 
                if (fileWriter != null) 
                    fileWriter.close(); 
            } catch (IOException e) { 
                e.printStackTrace(); 
            } 
        } 
 
        return isSuccess; 
    } 

我們把這兩個函數(shù)封裝到一個FileReaderWriter.java文件中以便后續(xù)使用。
接著我們回到知乎爬蟲中。
我們需要給知乎的Zhihu封裝類加個函數(shù),用來格式化寫入到本地時的排版。

復(fù)制代碼 代碼如下:

public String writeString() { 
        String result = ""; 
        result += "問題:" + question + "\r\n"; 
        result += "描述:" + questionDescription + "\r\n"; 
        result += "鏈接:" + zhihuUrl + "\r\n"; 
        for (int i = 0; i < answers.size(); i++) { 
            result += "回答" + i + ":" + answers.get(i) + "\r\n"; 
        } 
        result += "\r\n\r\n"; 
        return result; 

OK,這樣就差不多了,接下來吧mian方法中的System.out.println改成

復(fù)制代碼 代碼如下:

// 寫入本地 
        for (Zhihu zhihu : myZhihu) { 
            FileReaderWriter.writeIntoFile(zhihu.writeString(), 
                    "D:/知乎_編輯推薦.txt", true); 
        } 

運行,便可以看到本來在控制臺看到的內(nèi)容已經(jīng)被寫到了本地的txt文件里:

大體一看沒什么問題,仔細(xì)看看發(fā)現(xiàn)問題:存在太多的html標(biāo)簽,主要是<b>和<br>。
我們可以在輸出的時候?qū)@些標(biāo)記進(jìn)行處理。
先把<br>換成io流里面的\r\n,再把所有的html標(biāo)簽都刪除,這樣看起來便會清晰很多。

復(fù)制代碼 代碼如下:

public String writeString() { 
    // 拼接寫入本地的字符串 
    String result = ""; 
    result += "問題:" + question + "\r\n"; 
    result += "描述:" + questionDescription + "\r\n"; 
    result += "鏈接:" + zhihuUrl + "\r\n"; 
    for (int i = 0; i < answers.size(); i++) { 
        result += "回答" + i + ":" + answers.get(i) + "\r\n\r\n"; 
    } 
    result += "\r\n\r\n\r\n\r\n"; 
    // 將其中的html標(biāo)簽進(jìn)行篩選 
    result = result.replaceAll("<br>", "\r\n"); 
    result = result.replaceAll("<.*?>", ""); 
    return result; 

這里的replaceAll函數(shù)可以使用正則,于是所有的<>標(biāo)簽在最后就都被刪除了。

相關(guān)文章

  • JAVA實現(xiàn)微信APPV3支付保姆級教程

    JAVA實現(xiàn)微信APPV3支付保姆級教程

    微信實現(xiàn)支付功能與支付寶實現(xiàn)支付功能是相似的,這篇文章主要介紹了JAVA實現(xiàn)微信APPV3支付的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-01-01
  • java 獲取mac地址的兩種方法(推薦)

    java 獲取mac地址的兩種方法(推薦)

    下面小編就為大家?guī)硪黄猨ava 獲取mac地址的兩種方法(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • java解析dbf之通過javadbf包生成和讀取dbf文件

    java解析dbf之通過javadbf包生成和讀取dbf文件

    這篇文章主要介紹了java通過javadbf讀取和生成DBF文件的方法,大家參考使用吧
    2014-01-01
  • 獲取Java的MyBatis框架項目中的SqlSession的方法

    獲取Java的MyBatis框架項目中的SqlSession的方法

    SqlSession中包括已經(jīng)映射好的SQL語句,這樣對象實例就可以直接拿過來用了,那么這里就來講解獲取Java的MyBatis框架項目中的SqlSession的方法
    2016-06-06
  • spring中REST和RESTful的區(qū)別以及基本實現(xiàn)

    spring中REST和RESTful的區(qū)別以及基本實現(xiàn)

    本文主要介紹了spring中REST和RESTful的區(qū)別以及基本實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • Java實現(xiàn)心跳機(jī)制的方法

    Java實現(xiàn)心跳機(jī)制的方法

    這篇文章主要介紹了Java實現(xiàn)心跳機(jī)制的方法,文中講解非常細(xì)致,幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • java雙向循環(huán)鏈表的實現(xiàn)代碼

    java雙向循環(huán)鏈表的實現(xiàn)代碼

    這篇文章介紹了java雙向循環(huán)鏈表的實現(xiàn)代碼,有需要的朋友可以參考一下
    2013-09-09
  • Springboot2.6.x高版本與Swagger2版本沖突問題解決方法

    Springboot2.6.x高版本與Swagger2版本沖突問題解決方法

    Spring Boot 2.6.x版本引入依賴?springfox-boot-starter?(Swagger?3.0) 后,啟動容器會報錯,本文就介紹一下Springboot2.6.x高版本與Swagger2版本沖突問題解決方法,感興趣的可以了解一下
    2022-04-04
  • JAVA返回PDF文件流并進(jìn)行下載的實現(xiàn)方法

    JAVA返回PDF文件流并進(jìn)行下載的實現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于JAVA返回PDF文件流并進(jìn)行下載的實現(xiàn)方法,PDF文件流下載是通過HTTP協(xié)議將服務(wù)器上的PDF文件以流的方式發(fā)送給客戶端,供客戶端保存到本地磁盤或直接在瀏覽器中打開,需要的朋友可以參考下
    2024-02-02
  • Springboot 接收POST、json、文本數(shù)據(jù)的方法 附示例

    Springboot 接收POST、json、文本數(shù)據(jù)的方法 附示例

    這篇文章主要介紹了Springboot 接收POST、json、文本數(shù)據(jù)實踐,如果把 json 作為參數(shù)傳遞,我們可以使用 @requestbody 接收參數(shù),將數(shù)據(jù)直接轉(zhuǎn)換成對象,本文通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10

最新評論