国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

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

2019-11-26 15:21:46
字體:
供稿:網(wǎng)友

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

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

public static boolean createNewFile(String filePath) { 
        boolean isSuccess = true; 
        // 如有則將"http://"轉(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)簽在最后就都被刪除了。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 芜湖县| 中超| 辛集市| 蚌埠市| 河南省| 田林县| 新安县| 开原市| 宝山区| 广汉市| 茂名市| 阿坝| 庄河市| 福贡县| 齐河县| 望江县| 玛曲县| 金沙县| 潮州市| 华容县| 泸西县| 康定县| 临猗县| 大安市| 邯郸县| 珲春市| 通化县| 大城县| 龙游县| 金乡县| 米易县| 喀什市| 随州市| 那曲县| 固始县| 郯城县| 府谷县| 南阳市| 伊宁市| 灵宝市| 武汉市|