我想从原始文本中获取所有获利价值。但是书写方式不一样。
我得到了我想要的所有值,除了20/30/50。对于那个值我只能得到20。
我希望整个单词都为20/30/50
$s = 'SS 1.0140 SL 1.0670 TP1 1.0870 TP 1 1.0870 TP 2 1.0870 Takeprofit1 1.0870 Take profit 1 1.0870 TP 1.0870 TP 20/30/50 TP-----1.0870 TP=1.0870 TP1=1.0870 TP Open';
$p = '#\b(TAKE ?PROFIT ?(?:[1-3]|\|TP|at)|TP ?(?:[1-3](?!\.\d))?)\b(.*?)\b(Open|(\d+(?:\.\d+)?))\b#i';
preg_match_all($p , $s , $m);
的结果$m[3]
:
Array
(
[3] => Array
(
[0] => 1.0870
[1] => 1.0870
[2] => 1.0870
[3] => 1.0870
[4] => 1.0870
[5] => 1.0870
[6] => 20
[7] => 1.0870
[8] => 1.0870
[9] => 1.0870
[10] => Open
)
)
添加(?:/\d+)*
到您的第三个捕获组。
https://regex101.com/r/hsQ0xD/1/
这使得重复的非捕获组(子字符串)“斜杠然后是一个或多个数字”是可选的。
代码:(演示)
$s = 'SS 1.0140 SL 1.0670 TP1 1.0870 TP 1 1.0870 TP 2 1.0870 Takeprofit1 1.0870 Take profit 1 1.0870 TP 1.0870 TP 20/30/50 TP-----1.0870 TP=1.0870 TP1=1.0870 TP Open';
$p = '#\b(TAKE ?PROFIT ?(?:[1-3]|\|TP|at)|TP ?(?:[1-3](?!\.\d))?)\b(.*?)\b(Open|(\d+(?:\.\d+)?(?:/\d+)*))\b#i';
preg_match_all($p , $s , $m);
var_export($m[3]);
输出:
array (
0 => '1.0870',
1 => '1.0870',
2 => '1.0870',
3 => '1.0870',
4 => '1.0870',
5 => '1.0870',
6 => '20/30/50',
7 => '1.0870',
8 => '1.0870',
9 => '1.0870',
10 => 'Open',
)
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句