html = '''
<span>Hello python
<p>python</p>
<p>hello</p>
</span>
'''
bs1 = BeautifulSoup(html, 'html.parser')
for bs_test in bs1.find('span').children:
print(bs_test)
输出:
为什么会有空行呢?
html = '''
<span>Hello python
<p>python</p>
<p>hello</p>
</span>
'''
bs1 = BeautifulSoup(html, 'html.parser')
for bs_test in bs1.find('span').children:
print(bs_test)
输出:
为什么会有空行呢?
4 回答4.4k 阅读✓ 已解决
4 回答3.8k 阅读✓ 已解决
3 回答2.1k 阅读✓ 已解决
1 回答4.5k 阅读✓ 已解决
1 回答3.8k 阅读✓ 已解决
1 回答2.8k 阅读✓ 已解决
2 回答1.9k 阅读✓ 已解决
因为你使用的是三引号, 三引号的形式用来输入多行文本,也就是说在三引号之间输入的内容将被原样保留,之中的单号和双引号不用转义,其中的不可见字符比如\n和\t都会被保留,所以你字符串每行后面都有一个’\n‘被打印出一个空行
关于两个<p>之间两个空行的问题,可以调试一下就知道了

第一次循环:
第二次循环:
第三次循环:
看到了原因了吧, \n是被单独提取出来