douqian6194 2017-12-25 21:07
浏览 17
已采纳

str_replace()不使用带有搜索参数变量的while循环

$query1 = mysqli_query($cone,"SELECT words FROM banlist ORDER BY words") or die(mysql_error());

while($row = mysqli_fetch_array($query1, MYSQLI_ASSOC)) {
    $fix = (string)$row['words'];                   
    $title = str_replace($fix, "-", $title);
}

echo $title;

var_dump($row)'s output:

array(1) {
    ["words"]=> string(5) "hello "
}
array(1) {
    ["words"]=> string(5) "you "
}

It doesn't replace any string in the title But if I put the values directly like "hello" in the place of $fix then it works fine.

  • 写回答

1条回答 默认 最新

  • doulou1989 2017-12-25 21:37
    关注

    Through some troubleshooting with you, we ascertained that it was the space coming from the database field. To correct the issue code should be changed to

    $query1 = mysqli_query($cone,"SELECT words FROM banlist ORDER BY words") or die(mysql_error());
    
    while($row = mysqli_fetch_array($query1, MYSQLI_ASSOC)) {
        $fix = trim($row['words']);                   
        $title = str_replace($fix, "-", $title);
    }
    
    echo $title;
    

    Ideally strings should be trimmed as they get inserted to the database to prevent this issue.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥100 需要跳转番茄畅听app的adb命令
  • ¥50 寻找一位有逆向游戏盾sdk 应用程序经验的技术
  • ¥15 请问有用MZmine处理 “Waters SYNAPT G2-Si QTOF质谱仪在MSE模式下采集的非靶向数据” 的分析教程吗
  • ¥50 opencv4nodejs 如何安装
  • ¥15 adb push异常 adb: error: 1409-byte write failed: Invalid argument
  • ¥15 nginx反向代理获取ip,java获取真实ip
  • ¥15 eda:门禁系统设计
  • ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页
  • ¥15 376.1电表主站通信协议下发指令全被否认问题
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证