将一个字符串按照<b>或者<p>或者<b/>等标签分割
时间: 2023-12-06 17:03:48 浏览: 66
可以使用正则表达式进行分割,具体实现如下:
```python
import re
text = "<b>Hello</b><p>World</p><b/>"
# 定义正则表达式
pattern = re.compile(r'<[^>]+>')
# 使用正则表达式进行分割
result = pattern.split(text)
print(result) # ['Hello', 'World', '']
```
解释一下正则表达式的含义:
- `<`: 匹配左尖括号
- `[^>]+`: 匹配任意数量的非右尖括号字符
- `>`: 匹配右尖括号
因此,`<[^>]+>` 可以匹配任意标签。使用 `pattern.split(text)` 可以将字符串按照标签进行分割。
相关问题
将一个字符串按照<b>或者<p>或者<b/>等标签分割,分割完后,将每个元素最后加上\n组成一个字符串并返回
可以使用正则表达式来匹配标签进行分割,然后再加上换行符组成一个字符串返回。下面是示例代码:
```python
import re
def split_and_join_tags(s):
# 使用正则表达式匹配标签进行分割
lst = re.split(r'<(b|p|b\/)>', s)
# 将每个元素最后加上\n组成一个字符串
res = ''.join([s+'\n' for s in lst])
return res
```
使用示例:
```python
s = 'hello<b>world</b>!<p>How are you?</p><b/>Fine, thank you!'
res = split_and_join_tags(s)
print(res)
```
输出结果:
```
hello
<b>world</b>
!
<p>How are you?</p>
<b/>
Fine, thank you!
```
阅读全文