|  support |  documentation |  report a bug |  advanced search |  search howto |  statistics |  random bug |  login
Doc Bug #77994 Missing Detail in str_replace Documentation
Submitted: 2019-05-09 06:13 UTC Modified: 2019-05-09 06:33 UTC
From: mark at manngo dot net Assigned:
Status: Not a bug Package: Documentation problem
PHP Version: Irrelevant OS:
Private report: No CVE-ID: None
 [2019-05-09 06:13 UTC] mark at manngo dot net
From manual page:

The document makes no mention of what happens if the replace array is smaller than the search array.

It appears that the search characters will be replaced with an empty string. This may or may not be expected, as the alternative result might have been to ignore the characters.

Test script:
$string='apple banana cherry apple banana cherry apple banana cherry';

print str_replace($search,$replace,$string);

print "\n";

print str_replace($search,$replace,$string);


Add a Patch

Pull Requests

Add a Pull Request


AllCommentsChangesGit/SVN commitsRelated reports
 [2019-05-09 06:18 UTC]
-Status: Open +Status: Not a bug
 [2019-05-09 06:18 UTC]
Sure it does.

> If replace has fewer values than search, then an empty string is used for the rest of replacement values.
 [2019-05-09 06:25 UTC] mark at manngo dot net
Gad, you’re right. Sorry, I missed that.

It might help to include an example, though.
 [2019-05-09 06:33 UTC]
I suppose? It's an unusual usage of the function. In fact I'd bet that most of the time someone uses str_replace with arrays (strtr is easier) and the two arrays aren't the same size, it's a bug - or at least unintentional.

If you have a use case in mind, you can hit the Edit link in the top-right corner and submit a patch including an example. (Or amend the existing "gotchas" example.) The docs are written in XML but there should be enough there to understand how it works.
PHP Copyright © 2001-2021 The PHP Group
All rights reserved.
Last updated: Wed May 12 20:01:28 2021 UTC