js用正则表达式获取字符串<p>你好</p>中的<p></p>
时间: 2023-07-09 22:20:25 浏览: 54
可以使用正则表达式 `/\<\/?p\>/g` 来获取字符串 `<p>你好</p>` 中的 `<p></p>` 标签。具体代码如下:
```javascript
var str = "<p>你好</p>";
var reg = /\<\/?p\>/g;
var matchResult = str.match(reg);
console.log(matchResult); // ["<p>", "</p>"]
```
在上面的代码中,`/\<\/?p\>/g` 是一个正则表达式,其中 `\<` 表示匹配 `<` 字符,`\>` 表示匹配 `>` 字符,`\/?` 表示匹配 `/` 字符出现 0 次或 1 次,`p` 表示匹配 `p` 字符。`g` 表示全局匹配,即查找所有匹配的结果。
然后,通过 `match()` 方法将字符串中所有匹配的结果存储在 `matchResult` 数组中,最后输出结果即可。
相关问题
js用正则表达式获取字符串'<p>你好</p>'中的'<p></p>'
可以使用正则表达式 `/\<p\>.*\<\/p\>/g` 来获取字符串 `<p>你好</p>` 中的 `<p></p>` 标签。具体代码如下:
```javascript
var str = "<p>你好</p>";
var reg = /\<p\>.*\<\/p\>/g;
var matchResult = str.match(reg);
console.log(matchResult); // ["<p>你好</p>"]
```
在上面的代码中,`/\<p\>.*\<\/p\>/g` 是一个正则表达式,其中 `\<p\>` 表示匹配 `<p>` 字符串,`.*` 表示匹配任意字符 0 次或多次,`\<\/p\>` 表示匹配 `</p>` 字符串。`g` 表示全局匹配,即查找所有匹配的结果。
然后,通过 `match()` 方法将字符串中所有匹配的结果存储在 `matchResult` 数组中,最后输出结果即可。
正则表达式 获取html中<li>与</li>之间的内容,要支持多行
可以使用以下正则表达式来匹配 html 中的 <li> 与 </li> 标签之间的内容:
```html
<li>([\s\S]*?)<\/li>
```
其中,`[\s\S]*?` 匹配任意多个字符,包括换行符,`()` 表示分组,`<\/li>` 匹配闭合标签。
如果要在 Python 中使用该正则表达式,可以使用 `re.findall()` 方法来获取所有匹配的结果:
```python
import re
html = '''
<ul>
<li>Item 1</li>
<li>
Item 2
with multiple lines
</li>
<li>Item 3</li>
</ul>
'''
pattern = r'<li>([\s\S]*?)<\/li>'
matches = re.findall(pattern, html)
for match in matches:
print(match.strip())
```
输出结果为:
```
Item 1
Item 2
with multiple lines
Item 3
```
注意,`match.strip()` 是为了去掉匹配结果中的前后空格。