首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >POSIX ERE (扩展正则表达式)中的正向或非捕获组

POSIX ERE (扩展正则表达式)中的正向或非捕获组
EN

Stack Overflow用户
提问于 2016-11-17 20:33:49
回答 2查看 554关注 0票数 0

在CSV文件中,有一些与此类似的行:

代码语言:javascript
复制
<iframe src="https://player.vimeo.com/video/30342373" width="640" height="364" frameborder="0" webkitallowfullscreen mozallowfullscreen allowfullscreen></iframe>

我想从这些行中提取30342373,它位于vimeo.com/video/"之间。我在mawk中尝试了以下正则表达式

代码语言:javascript
复制
vimeo\.com\/video\/[^"]*

它正在捕获:vimeo.com/video/30342373

如果我知道得对,mawk只支持POSIX语法,这与egrep类似。

我如何才能从线上捕获唯一的视频标识部分?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-11-17 20:44:53

代码语言:javascript
复制
$ awk '{gsub(/.*vimeo.com\/video\/|".*/,"")}1' file
30342373
票数 1
EN

Stack Overflow用户

发布于 2016-11-17 20:43:45

使用sed更容易

代码语言:javascript
复制
str='<iframe src="https://player.vimeo.com/video/30342373" width="640" height="364" frameborder="0" webkitallowfullscreen mozallowfullscreen allowfullscreen></iframe>'

sed 's~.*\.vimeo\.com/video/~~; s~" .*~~' <<< "$str"

30342373

这个sed首先剥离从开始到vimeo.com/video/的所有内容,然后剥离从"到结束的所有内容,从而留给我们唯一的id。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40664481

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档