我需要从json字符串中抓取数据,我当前的代码是:
import re
>>> output = """
... Uploading file 'ex4-to-mq4-ps-decompiler.mp4'...
... Progress: 13.29 Mbps, 3703728 / 3703084 (100.017%) ETA 0s
... Upload successful! Video ID: tZ5xaRLhljc
... Video added to playlist 'decompile mql4' (PL2Q1nwGTMjdeAsBn6mcQ7KuFo6K7_g8_L)
... Video added to playlist 'decompile ex4' (PL2Q1nwGTMjdffMBkc6L4r6SeXnjz7eUiP)
... """
re.search("Video ID: (.+)", output, re.S).group(1)
>>> re.search("Video ID: (.+)?", output, re.S).group(1)
"tZ5xaRLhljc\nVideo added to playlist 'decompile mql4' (PL2Q1nwGTMjdeAsBn6mcQ7KuFo6K7_g8_L)\nVideo added to playlist 'decompile ex4' (PL2我只需要提取视频tZ5xaRLhljc的id,我可以这样做吗?
发布于 2018-08-21 21:13:55
re.S是re.DOTALL,它使.匹配换行符\n字符。如果将其删除,.将不再匹配换行符,您的代码将正常工作。也许是一个更安全的解决方案
re.search(r"Video ID: (\w+)", output).group(1)其中\w匹配所有"word“字符(即非空格)。
发布于 2018-08-21 21:14:27
试试这个:
re.search("Video ID: (.+)\n", output).group(1)https://stackoverflow.com/questions/51949457
复制相似问题