繁体   English   中英

Perl Regex在两个相同字符之间获取子字符串

[英]Perl Regex to get a substring between two of the same characters

给定一些字符串originalString = "#SomeWord# More words" ,我希望能够从originalString获得子字符串"SomeWord"

my $substr = (split /#/, $originalString)[1];

/#([^#]+)#/对我有用。

一些语法说明:

  • //标记正则表达式开始和结束的定界符
  • #文字哈希标记
  • []字符类

上面的正则表达式的解释:

  • [^#]任何非井号的字符
  • [^#]+一个或多个此类字符
  • ([^#]+)捕获组

在这种情况下,正则表达式将查找两个#之间的任何非#字符。 这是一个完整的示例:

my $foo = "#SomeWord# More words";

if ($foo =~ /#([^#]+)#/) {
    print "$1\n";
} else {
    print "no match\n";
}

您还可以使用正则表达式:

$originalString=~ /\#([^#]+)\#/;
# Now $1 holds your required string

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM