假设我将以下内容放入一个文本框:
1|[Guangzhou Evergrande](//www.gzevergrandefc.com/)|6|5-1-0|+15|**16**
2|[Shandong Luneng](//www.lunengsports.com/)|7|5-1-1|+7|**16**
3|[Qingdao Jonoon](//www.zhongnengfc.com/)|7|4-3-0|+4|**15**
4|[Beijing Guoan](//www.fcguoan.com/)|7|3-3-1|+2|**12**
当我按回车键时,它将获取[
和]
之间以及(
和)
之间的内容,并将其放入新的行中,如:
if ($name == "NAME_HERE") $name = "[".$name."](URL_HERE)";
我试着做preg_match
和使用这种模式:$pattern = '/^[/';
和$pattern_end = '/^]/';
的名称-只是为了测试-但我不能让它工作....
到目前为止我写的是:
$string = '1|[Guangzhou Evergrande](//www.gzevergrandefc.com/)|6|5-1-0|+15|**16**';
$pattern = '/'[(.*?')].*?'((.*?)')/';
$replacement = 'if ($name == "{1}") $name = "[".$name."]({2})";';
echo preg_replace($pattern, $replacement, $string);
你的样式应该是
'/'[(.*?)']'((.*?)')/'
,因为[]和()是特殊字符。使用preg_match_all()函数
当你使用preg_match_all时,你可以为submatches(subpattern)设置()
例子<?php
$string = '1|[Guangzhou Evergrande](//www.gzevergrandefc.com/)|6|5-1-0|+15|**16**';
$matches = array();
preg_match_all("/(<(['w]+)[^>]*>)(.*?)(<'/''2>)/", $string, $matches);
var_dump($matches);
?>
也许我不完全理解您在这里做什么,但是,我看到了一个可以轻松分解的数据结构。例如:
function get_football( $text ) {
$r = array();
$t = explode("'n", $text );
foreach( $t as $l ) {
$n = explode("|", $l);
$r[] = $n;
}
return( $r );
}
这将为您提供一个结构良好的数据集,您可以通过foreach()进行进一步处理。如果原始文本存储在$variable0中,print_r( get_football( $variable0 ) );
将显示一个很好的结构:
Array
(
[0] => Array
(
[0] => 1
[1] => [Guangzhou Evergrande](//www.gzevergrandefc.com/)
[2] => 6
[3] => 5-1-0
[4] => +15
[5] => **16**
)
[1] => Array
当然,这个$n[1]名称可以在循环中进一步分解。无论如何,此后,您可以使用foreach()循环遍历正在构建的任何菜单,而不是硬编码菜单选项。只是考虑一下。