当前位置:  开发笔记 > 编程语言 > 正文

如何使用PHP修剪文本

如何解决《如何使用PHP修剪文本》经验,为你挑选了2个好方法。

如何在php中修剪一些单词?例如

pid="5" OR pid="3" OR

我想删除最后一个 OR



1> Jeremy Ruten..:

我建议使用implode()这样的SQL表达式.首先构建一个简单表达式数组,然后使用OR内爆它们:

$pids = array('pid = "5"', 'pid = "3"');

$sql_where = implode(' OR ', $pids);

现在$sql_where是字符串'pid = "5" OR pid = "3"'.即使只有一个元素,您也不必担心剩余的OR $pids.

此外,一个完全不同的解决方案是附加" false"到您的SQL字符串,以便它将结束,"... OR false"使其成为一个有效的表达式.

@RussellDias的回答是你问题的真正答案,这些只是思考的一些选择.



2> Russell Dias..:

你可以尝试rtrim:

rtrim - 从字符串末尾删除空格(或其他字符)

$string = "pid='5' OR pid='3' OR";
echo rtrim($string, "OR"); //outputs pid='5' OR pid='3'


@col.弹片:糟糕的一天?
使用rtrim()在这里很好,有点聪明(并且可能受到问题措辞的影响),并且比substr()更清楚地显示语句的目的.我们修剪"或"一词从 $ string r 结尾处移开.它确实看起来像rtrim()工作在单词级别而不是char级别(我甚至没有意识到这一点,直到Col Shrapnel最终拼写出来),但我认为在这种情况下,你知道你的字符串将永远结束在"或"中,这是一个很好的方式来削减它.
另一个SO风格的应答机器人.
杰里米,你现在才知道.几年后维护人员无法保证这个黑客行为.一个没有怪癖或副问题的清晰,独立的解决方案通常最适合可维护性.您自己的解决方案是一个出色的解决方案示例,您可以轻松地在查询中添加更多参数而不会破坏任何内容.rtrim()并不是那么优秀,因为它确实有怪癖和非明显的副作用.
rtrim()将从末尾删除"OR",但它也会删除"RO",或者只删除"R"或"O",如果这是字符串恰好结束的话.它可能不是最强大的解决方案,但它有效,而且我认为它并不像它已经被证明的那样邪恶.
推荐阅读
周扒pi
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有