零基礎(chǔ)寫(xiě)Java知乎爬蟲(chóng)之將抓取的內(nèi)容存儲(chǔ)到本地
說(shuō)到Java的本地存儲(chǔ),肯定使用IO流進(jìn)行操作。
首先,我們需要一個(gè)創(chuàng)建文件的函數(shù)createNewFile:
public static boolean createNewFile(String filePath) {
boolean isSuccess = true;
// 如有則將"\\"轉(zhuǎn)為"/",沒(méi)有則不產(chǎn)生任何變化
String filePathTurn = filePath.replaceAll("\\\\", "/");
// 先過(guò)濾掉文件名
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;
}
然后,我們需要一個(gè)寫(xiě)入文件的函數(shù):
public static boolean writeIntoFile(String content, String filePath,
boolean isAppend) {
boolean isSuccess = true;
// 先過(guò)濾掉文件名
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();
}
// 寫(xiě)入文件
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;
}
我們把這兩個(gè)函數(shù)封裝到一個(gè)FileReaderWriter.java文件中以便后續(xù)使用。
接著我們回到知乎爬蟲(chóng)中。
我們需要給知乎的Zhihu封裝類(lèi)加個(gè)函數(shù),用來(lái)格式化寫(xiě)入到本地時(shí)的排版。
public String writeString() {
String result = "";
result += "問(wèn)題:" + 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,這樣就差不多了,接下來(lái)吧mian方法中的System.out.println改成
// 寫(xiě)入本地
for (Zhihu zhihu : myZhihu) {
FileReaderWriter.writeIntoFile(zhihu.writeString(),
"D:/知乎_編輯推薦.txt", true);
}
運(yùn)行,便可以看到本來(lái)在控制臺(tái)看到的內(nèi)容已經(jīng)被寫(xiě)到了本地的txt文件里:

大體一看沒(méi)什么問(wèn)題,仔細(xì)看看發(fā)現(xiàn)問(wèn)題:存在太多的html標(biāo)簽,主要是<b>和<br>。
我們可以在輸出的時(shí)候?qū)@些標(biāo)記進(jìn)行處理。
先把<br>換成io流里面的\r\n,再把所有的html標(biāo)簽都刪除,這樣看起來(lái)便會(huì)清晰很多。
public String writeString() {
// 拼接寫(xiě)入本地的字符串
String result = "";
result += "問(wèn)題:" + 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)簽在最后就都被刪除了。
- JAVA使用爬蟲(chóng)抓取網(wǎng)站網(wǎng)頁(yè)內(nèi)容的方法
- 零基礎(chǔ)寫(xiě)Java知乎爬蟲(chóng)之抓取知乎答案
- Java爬蟲(chóng)實(shí)戰(zhàn)抓取一個(gè)網(wǎng)站上的全部鏈接
- Java爬蟲(chóng)抓取視頻網(wǎng)站下載鏈接
- java爬蟲(chóng)Gecco工具抓取新聞實(shí)例
- java正則表達(dá)式簡(jiǎn)單使用和網(wǎng)頁(yè)爬蟲(chóng)的制作代碼
- 基于Java HttpClient和Htmlparser實(shí)現(xiàn)網(wǎng)絡(luò)爬蟲(chóng)代碼
- java實(shí)現(xiàn)簡(jiǎn)單的爬蟲(chóng)之今日頭條
- Java實(shí)現(xiàn)的爬蟲(chóng)抓取圖片并保存操作示例
- 一篇文章教會(huì)你使用java爬取想要的資源
相關(guān)文章
SpringBoot利用@Retryable注解實(shí)現(xiàn)接口重試
本文主要介紹了springboot如何利用@Retryable注解實(shí)現(xiàn)接口重試功能,文中示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
Java實(shí)現(xiàn)文件或文件夾的復(fù)制到指定目錄實(shí)例
本篇文章主要介紹了Java實(shí)現(xiàn)文件或文件夾的復(fù)制到指定目錄實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-03-03
spring框架配置實(shí)體類(lèi)復(fù)雜屬性注入xml文件過(guò)程詳解
這篇文章主要介紹了spring框架配置實(shí)體類(lèi)復(fù)雜屬性注入xml文件過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09
深入探究 spring-boot-starter-parent的作用
這篇文章主要介紹了spring-boot-starter-parent的作用詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,感興趣的小伙伴可以跟著小編一起來(lái)學(xué)習(xí)一下2023-05-05
Java同步框架AbstractQueuedSynchronizer詳解
本篇文章主要介紹了Java同步框架AbstractQueuedSynchronizer詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10
Java前后端分離的在線點(diǎn)餐系統(tǒng)實(shí)現(xiàn)詳解
這是一個(gè)基于SpringBoot+Vue框架開(kāi)發(fā)的在線點(diǎn)餐系統(tǒng)。首先,這是一個(gè)前后端分離的項(xiàng)目。具有一個(gè)在線點(diǎn)餐系統(tǒng)該有的所有功能,感興趣的朋友快來(lái)看看吧2022-01-01

