我有一个下载的HTML文件的目录(其中46个),我试图遍历每个文件,读取它们的内容,去掉HTML,并只将文本附加到文本文件中。但是,我不确定我在哪里搞砸了,因为我的文本文件中什么也没写?在import os
import glob
from bs4 import BeautifulSoup
path = "/"
for infile in glob.glob(os.path.join(path, "*.html")):
markup = (path)
soup = BeautifulSoup(markup)
with open("example.txt", "a") as myfile:
myfile.write(soup)
f.close()
----更新----
我已经更新了我的代码如下,但是文本文件仍然没有被创建。在
^{pr2}$
-----更新2---
啊,我发现我的目录不正确,所以现在我:import os
import glob
from bs4 import BeautifulSoup
path = "c:\\users\\me\\downloads\\"
for infile in glob.glob(os.path.join(path, "*.html")):
markup = (infile)
soup = BeautifulSoup(markup)
with open("example.txt", "a") as myfile:
myfile.write(soup)
myfile.close()
执行此操作时,我得到以下错误:Traceback (most recent call last):
File "C:\Users\Me\Downloads\bsoup.py, line 11 in
myfile.write(soup)
TypeError: must be str, not BeautifulSoup
我通过改变myfile.write(soup)
到myfile.write(soup.get_text())
-----更新3----
它现在正常工作,工作代码如下:import os
import glob
from bs4 import BeautifulSoup
path = "c:\\users\\me\\downloads\\"
for infile in glob.glob(os.path.join(path, "*.html")):
markup = (infile)
soup = BeautifulSoup(open(markup, "r").read())
with open("example.txt", "a") as myfile:
myfile.write(soup.get_text())
myfile.close()