explode('!', $str) 失效主因是字符串含全角感叹号“!”而非半角“!”,需先用str_replace转半角或preg_split正则兼容;空元素须array_filter($parts, 'strlen')过滤;性能敏感时单字符分隔优先用explode,多符号用preg_split。
explode('!', $str) 有时不按预期分割?感叹号本身不是特殊字符,explode 对它没有额外处理——问题通常出在数据本身。最常见的是字符串里实际包含的是全角感叹号 !(Unicode U+FF01),而非 ASCII 的 !(U+0021)。直接用 explode('!', $str) 会完全失效,返回原字符串组成的单元素数组。
实操建议:
bindec(base_convert(bin2hex($str), 16, 2)) 或更直观的 echo urlencode($str) 检查原始字符编码,确认是 %21 还是 %EF%BC%81
$str = str_replace('!', '!', $str); explode('!', $str);
preg_split('/[!!]/u', $str, -1, PREG_SPLIT_NO_EMPTY)
explode 分割后空元素怎么过滤?连续感叹号(如 "a!!b")或开头/结尾带感叹号(如 "!a!b!")会导致 explode 产生空字符串元素。默认不会自动剔除,容易引发后续 foreach 中的 Notice: Undefined index 等问题。
实操建议:
PREG_SPLIT_NO_EMPTY 不适用——
preg_split 用的;explode 本身无内置过滤参数array_filter($parts, 'strlen'),注意不要只写 array_filter($parts),否则值为 0 或 '0' 的合法项也会被误删str_split 配合 str_replace 拆解,但通常不如先 explode 再 array_filter 直观explode 和 preg_split 怎么选?纯单字符分割(如固定用 !),explode 比 preg_split 快 3–5 倍,且内存占用更低。正则引擎启动成本明显,尤其在循环内高频调用时。
实操建议:
! → 无条件选 explode('!', $str)
!、!、甚至 ‼(双感叹号)→ 改用 preg_split('/[!!‼]/u', $str),别硬凑多个 str_replace + explode
strpos + substr 手动截取,避免生成完整数组explode 的第三个参数 $limit 边界行为$limit 控制最多返回几个元素,但它的切分逻辑容易误解:当 $limit = 2 时,explode('!', 'a!b!c!d', 2) 返回 ['a', 'b!c!d'],即**只切第一处,剩余部分原样保留**,不是“取前两段”。
实操建议:
array_slice(explode('!', $str), 0, 3)
array_pad
$limit = -1 会忽略末尾空元素(PHP 7.4+),但不解决开头/中间的空项,仍需 array_filter
null。动手前先 var_dump 原始字符串,比查文档更快定位问题。