1

我不确定这个问题是我的嘘声还是关于 CI 的问题。我有一个 preg_replace 进程将已发布的 gdoc 电子表格 url 转换回原始电子表格 url。

$pat ='/(^[a-z\/\.\:]*?sheet\/)(pub)([a-zA-Z0-9\=\?]*)(\&output\=html)/';
$rep ='$1ccc$3#gid=0';

$theoriginal = preg_replace( $pat, $rep, $published );

这在本地运行的测试页面中运行良好。这个测试页面不是由 CI 构建的——它只是一个基本的 php 页面。

当我将模式和替换复制并粘贴到它打算用于的 CI 视图中时,没有任何乐趣。

这个故障是由 CI 还是我的“坏”引起的?是否有易于实施的补救措施?

下面是来自 CI 视图的更多代码:

    <body id="sites" >

<?php 

foreach ( $dets as $item )
{
    $nona = $item->nona;
    $address = $item->address;
    $town = $item->town;
    $pc = $item->pc;
    $foto1 = $item->foto1;
    $foto1txt = $item->foto1txt;
    $foto2 = $item->foto2;
    $foto2txt = $item->foto2txt;
    $costurl = $item->costurl;
    $sid = $item->sid;
}

//convert published spreadsheet url to gdoc spreadsheet url
$pat ='/(^[a-z\/\.\:]*?sheet\/)(pub)([a-zA-Z0-9\=\?]*)(\&output\=html)/i';
$rep ='$1ccc$3#gid=0';

$spreadsheet = preg_replace( $pat, $rep, $costurl);

汤姆

4

1 回答 1

1

你来的模式可以“整理”一下:

~^(.*?sheet/)pub(.*)(&[a-z=]*)$~

请参阅正则表达式演示

前导^和尾随$通常不放在组内。如果/您使用除/. A &and=不是特殊的正则表达式元字符,=仅在积极的环视结构中是“特殊的”。所以,你的模式意味着:

  • ^- 字符串锚的开始
  • (.*?sheet/)- 第 1 组:除换行符之外的任何 0+ 字符,尽可能少(因为我相信重点是仅pub在 URL 路径中匹配,而不是在查询字符串中,您需要实际替换.*?[^?#]*?匹配 0 的否定字符类+#和)以外的字符?,直到第一次出现sheet/和随后的子模式...
  • pub- 一个子串
  • (.*)- 第 2 组:除换行符之外的任何 0+ 个字符,尽可能多,直到最后出现的后续子模式...
  • (&[a-z=]*)- 第 3 组:a&后跟 0 个或多个 ASCII 字母(由于i使用了修饰符,[a-z]模式也将匹配大写字母)和/或=
  • $- 字符串锚的末端。

在我看来,您还可以使用更好的模式,例如

~^([^?#]*?sheet/)pub(.*)(&[a-z=]*)$~
   ^^^^^^

请参阅此正则表达式演示。上述说明中提供了更改的说明。

于 2017-06-25T20:48:43.463 回答