鱼C论坛

 找回密码
 立即注册
查看: 658|回复: 17

[已解决]我想匹配<form>......</form> 之间的文本

[复制链接]
发表于 2019-5-23 15:50:33 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
源文本太长  没贴,
(?<=<form>)(.+)(?=<\/form>)
咋啥都匹配不到呢
最佳答案
2019-5-24 07:53:21
  1. import re
  2. import requests
  3. url='http://qz.jessiepowell.top/fquiz/push/2655022/ni-de-yin-yang-bi-li-shi-duo-shao?rd=1#'
  4. s=requests.get(url).text
  5. lis=re.findall(r'<li class="qz\d+[^>]+>(.+?)</li>',
  6.                    s, re.M | re.S)
  7. for li in lis:
  8.     myre=re.findall(r'title-in">([^>]+)</(?:.*?<span>(.*?)</)?(?:.*?<span>(.*?)</)?(?:.*?<span>(.*?)</)?'
  9.                       r'(?:.*?<span>(.*?)</)?(?:.*?<span>(.*?)</)?(?:.*?<span>(.*?)</)?(?:.*?<span>(.*?)</)?'
  10.                       r'(?:.*?<span>(.*?)</)?(?:.*?<span>(.*?)</)?',
  11.                      li, re.M | re.S)

  12.     print([i for i in myre[0] if len(i)])

  13. '''
  14. ['异性初次见面,你会最先注意ta的?', '脸', '鞋', '衣着', '发型', '其他']
  15. ['凭感觉选一组排列让你舒适的糖豆', '黄色-左上', '橘色-右上', '绿色-左下', '蓝色-右下']
  16. ['凭感觉,你觉得自己用左脑还是右脑多?', '左脑', '右脑']
  17. ['第一眼看到的动物是?', '猫头鹰', '考拉', '狮子', '兔子', '猪', '长颈鹿', '熊', '大象', '猫']
  18. ['下面哪幅图,让你有恋爱or想结婚的欲望?']
  19. ['选一个喜欢的动物']
  20. ['你的性别是?', '男', '女']

  21. '''
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-5-23 16:06:44 | 显示全部楼层
\/用反斜杠?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-23 16:10:05 | 显示全部楼层
\<form\>(.+?)\<\/form\>
应该是这个吧,<和>都要转义的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-5-23 16:19:21 | 显示全部楼层

有这么个提示 ,英语不好,貌似<>不用转义
批注 2019-05-23 161648.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-23 16:31:41 | 显示全部楼层
wp231957 发表于 2019-5-23 16:19
有这么个提示 ,英语不好,貌似不用转义

是不用,但是你的多了个反斜杠知道吗后面form前不要
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-5-23 16:33:32 | 显示全部楼层
塔利班 发表于 2019-5-23 16:31
是不用,但是你的多了个反斜杠知道吗后面form前不要

原始文本就有这个/ 啊  </form>   只匹配form 是不行的  那就能XXXform formXXX 都能匹配到
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-5-23 16:36:35 | 显示全部楼层
塔利班 发表于 2019-5-23 16:31
是不用,但是你的多了个反斜杠知道吗后面form前不要

这样也不行
批注 2019-05-23 163556.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-23 18:05:21 From FishC Mobile | 显示全部楼层
r'<form>(.*?)</form>'
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-23 18:06:46 | 显示全部楼层
我发现你要抓的东西,貌似和我练的一样,你可以教教我吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-5-23 19:11:51 | 显示全部楼层

匹配不到啊

有空可以帮我看一下  这个文件, <form></form> 配对大约有2对,我要第二对  位于文件1402行---1748行

我把这个form 换成div 花括号啥的  都能匹配到  

123.rar

31.73 KB, 下载次数: 2

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-5-23 19:13:38 | 显示全部楼层
一穷二白 发表于 2019-5-23 18:06
我发现你要抓的东西,貌似和我练的一样,你可以教教我吗

我还没弄明白呢  那个网站 不知道做了啥防护,xpath 取节点 取不到  
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-23 20:40:10 | 显示全部楼层
(?<=<form>)(.+)(?=<\/form>)我只让你去了最后一个反斜杠,不知道你整的什么
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-23 21:59:19 | 显示全部楼层
wp231957 发表于 2019-5-23 19:11
匹配不到啊

有空可以帮我看一下  这个文件,  配对大约有2对,我要第二对  位于文件1402行---1748行

1.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-23 22:02:54 | 显示全部楼层
html 中没有这个字符<form>,所以啥也匹配不到.<form> 和 <form action="" method="post" id="quizform">两个是不同的,后者带有属性.
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-23 22:04:02 | 显示全部楼层
results=re.findall(r'<form(.*?)</form>',s,re.M|re.S)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2019-5-24 01:35:32 | 显示全部楼层
本帖最后由 yjsx86 于 2019-5-24 01:43 编辑

正则的普通模式 "." 表示可打印字符并不包含"\n"
在多行字符串中查找时 需要带上flag=re.S

还有一点 xpath 是用来查找 文本内容的 , 你查找的内容中含有html的dom元素,当然会找不到

  1. import re

  2. with open("123.txt", "r") as f:
  3.     info = f.read()

  4. r = re.findall(r'<form.*?>(.*?)</form>', info, re.S)

  5. for item in r:
  6.     print("分割-----------------------------------------------------------")
  7.     print(item)
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-24 07:53:21 | 显示全部楼层    本楼为最佳答案   
  1. import re
  2. import requests
  3. url='http://qz.jessiepowell.top/fquiz/push/2655022/ni-de-yin-yang-bi-li-shi-duo-shao?rd=1#'
  4. s=requests.get(url).text
  5. lis=re.findall(r'<li class="qz\d+[^>]+>(.+?)</li>',
  6.                    s, re.M | re.S)
  7. for li in lis:
  8.     myre=re.findall(r'title-in">([^>]+)</(?:.*?<span>(.*?)</)?(?:.*?<span>(.*?)</)?(?:.*?<span>(.*?)</)?'
  9.                       r'(?:.*?<span>(.*?)</)?(?:.*?<span>(.*?)</)?(?:.*?<span>(.*?)</)?(?:.*?<span>(.*?)</)?'
  10.                       r'(?:.*?<span>(.*?)</)?(?:.*?<span>(.*?)</)?',
  11.                      li, re.M | re.S)

  12.     print([i for i in myre[0] if len(i)])

  13. '''
  14. ['异性初次见面,你会最先注意ta的?', '脸', '鞋', '衣着', '发型', '其他']
  15. ['凭感觉选一组排列让你舒适的糖豆', '黄色-左上', '橘色-右上', '绿色-左下', '蓝色-右下']
  16. ['凭感觉,你觉得自己用左脑还是右脑多?', '左脑', '右脑']
  17. ['第一眼看到的动物是?', '猫头鹰', '考拉', '狮子', '兔子', '猪', '长颈鹿', '熊', '大象', '猫']
  18. ['下面哪幅图,让你有恋爱or想结婚的欲望?']
  19. ['选一个喜欢的动物']
  20. ['你的性别是?', '男', '女']

  21. '''
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-24 08:46:36 | 显示全部楼层
1.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-13 01:40

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表