जवाबों:
Preg_replace के साथ किया जा सकता है :
function str_replace_first($from, $to, $content)
{
$from = '/'.preg_quote($from, '/').'/';
return preg_replace($from, $to, $content, 1);
}
echo str_replace_first('abc', '123', 'abcdef abcdef abcdef');
// outputs '123def abcdef abcdef'
मैजिक वैकल्पिक चौथे पैरामीटर [सीमा] में है। प्रलेखन से:
[सीमा] - प्रत्येक विषय स्ट्रिंग में प्रत्येक पैटर्न के लिए अधिकतम संभव प्रतिस्थापन। -1 की कमी (कोई सीमा नहीं)।
हालांकि, एक अधिक कुशल विधि (मोटे तौर पर 3-4x तेज) के लिए ज़ोम्बैट का जवाब देखें ।
preg_quote
? उदाहरण के लिए, @ThomasRedstone चिंता करता है कि /
यदि यह दिखाई देता है तो सीमांकक खतरनाक हो सकता है $from
, लेकिन सौभाग्य से ऐसा नहीं है: यह ठीक से बच गया है क्योंकि preg_quote
दूसरा पैरामीटर (कोई भी आसानी से परीक्षण कर सकता है)। मैं विशिष्ट मुद्दों (जो मेरी किताब में गंभीर पीसीआरई सुरक्षा कीड़े होंगे) के बारे में सुनना चाहूंगा।
इसका कोई संस्करण नहीं है, लेकिन समाधान बिल्कुल भी हैक नहीं है।
$pos = strpos($haystack, $needle);
if ($pos !== false) {
$newstring = substr_replace($haystack, $replace, $pos, strlen($needle));
}
बहुत आसान है, और नियमित अभिव्यक्ति के प्रदर्शन दंड बचाता है।
बोनस: यदि आप अंतिम घटना को बदलना चाहते हैं , तो इसके strrpos
स्थान पर उपयोग करें strpos
।
substr_replace
सभी मापदंडों के कारण उपयोग करने के लिए कुछ हद तक अनौपचारिक कार्य है, वास्तविक मुद्दा यह है कि संख्याओं द्वारा स्ट्रिंग हेरफेर करना कभी-कभी मुश्किल है - आपको कार्यों के लिए सही चर / ऑफसेट पास करने के लिए सावधान रहना होगा। मैं वास्तव में इतना कहना चाहूंगा कि उपरोक्त कोड सबसे सीधा है, और मेरे लिए, तार्किक, दृष्टिकोण।
संपादित करें: दोनों उत्तर अपडेट कर दिए गए हैं और अब सही हैं। मैं जवाब छोड़ दूंगा क्योंकि फंक्शन टाइमिंग अभी भी उपयोगी है।
'ज़ोम्बैट' और 'बहुत ज़्यादा php' के जवाब दुर्भाग्य से सही नहीं हैं। यह उत्तर ज़ोम्बैट के लिए एक संशोधन है (जैसा कि मेरे पास टिप्पणी पोस्ट करने के लिए पर्याप्त प्रतिष्ठा नहीं है):
$pos = strpos($haystack,$needle);
if ($pos !== false) {
$newstring = substr_replace($haystack,$replace,$pos,strlen($needle));
}
स्ट्रलेन ($ बदलें) के बजाय स्ट्रलेन ($ सुई) पर ध्यान दें। ज़ोम्बैट का उदाहरण केवल सही ढंग से काम करेगा यदि सुई और प्रतिस्थापित समान लंबाई हैं।
यहाँ PHP के अपने str_replace के समान हस्ताक्षर वाले फ़ंक्शन में समान कार्यक्षमता है:
function str_replace_first($search, $replace, $subject) {
$pos = strpos($subject, $search);
if ($pos !== false) {
return substr_replace($subject, $replace, $pos, strlen($search));
}
return $subject;
}
यह 'बहुत ज्यादा php' का संशोधित उत्तर है:
implode($replace, explode($search, $subject, 2));
1. के बजाय अंत में 2 नोट करें या फ़ंक्शन प्रारूप में:
function str_replace_first($search, $replace, $subject) {
return implode($replace, explode($search, $subject, 2));
}
मैंने दो कार्यों को समय पर किया और पहला मैच दो बार तेज है जब कोई मैच नहीं मिला। एक मैच मिलने पर वे समान गति वाले होते हैं।
मुझे आश्चर्य हुआ कि कौन सा सबसे तेज था, इसलिए मैंने उन सभी का परीक्षण किया।
नीचे आप पाएंगे:
सभी कार्यों को एक ही सेटिंग के साथ परीक्षण किया गया था:
$string = 'OOO.OOO.OOO.S';
$search = 'OOO';
$replace = 'B';
ऐसे कार्य जो स्ट्रिंग के भीतर एक स्ट्रिंग की पहली घटना को प्रतिस्थापित करते हैं :
substr_replace($string, $replace, 0, strlen($search));
[CONTRIBUTED BY] => zombat
[OOO.OOO.OOO.S] => B.OOO.OOO.S
[AVERAGE TIME] => 0.0000062883
[SLOWER BY] => FASTEST
replace_first($search, $replace, $string);
[CONTRIBUTED BY] => too much php
[OOO.OOO.OOO.S] => B.OOO.OOO.S
[AVERAGE TIME] => 0.0000073902
[SLOWER BY] => 17.52%
preg_replace($search, $replace, $string, 1);
[CONTRIBUTED BY] => karim79
[OOO.OOO.OOO.S] => B.OOO.OOO.S
[AVERAGE TIME] => 0.0000077519
[SLOWER BY] => 23.27%
str_replace_once($search, $replace, $string);
[CONTRIBUTED BY] => happyhardik
[OOO.OOO.OOO.S] => B.OOO.OOO.S
[AVERAGE TIME] => 0.0000082286
[SLOWER BY] => 30.86%
str_replace_limit($search, $replace, $string, $count, 1);
[CONTRIBUTED BY] => bfrohs - expanded renocor
[OOO.OOO.OOO.S] => B.OOO.OOO.S
[AVERAGE TIME] => 0.0000083342
[SLOWER BY] => 32.54%
str_replace_limit($search, $replace, $string, 1);
[CONTRIBUTED BY] => renocor
[OOO.OOO.OOO.S] => B.OOO.OOO.S
[AVERAGE TIME] => 0.0000093116
[SLOWER BY] => 48.08%
str_replace_limit($string, $search, $replace, 1, 0);
[CONTRIBUTED BY] => jayoaK
[OOO.OOO.OOO.S] => B.OOO.OOO.S
[AVERAGE TIME] => 0.0000093862
[SLOWER BY] => 49.26%
एक स्ट्रिंग के भीतर केवल एक स्ट्रिंग की अंतिम घटना को प्रतिस्थापित करने वाले कार्य :
substr_replace($string, $replace, strrpos($string, $search), strlen($search));
[CONTRIBUTED BY] => oLinkSoftware - modified zombat
[OOO.OOO.OOO.S] => OOO.OOO.B.S
[AVERAGE TIME] => 0.0000068083
[SLOWER BY] => FASTEST
strrev(implode(strrev($replace), explode(strrev($search), strrev($string), 2)));
[CONTRIBUTED BY] => oLinkSoftware
[OOO.OOO.OOO.S] => OOO.OOO.B.S
[AVERAGE TIME] => 0.0000084460
[SLOWER BY] => 24.05%
substr_replace()
परिणाम जीतने का कारण सरल है; क्योंकि यह एक आंतरिक कार्य है। आंतरिक और उपयोगकर्ता-परिभाषित कार्य करने वाले दो कार्य समान हैं, क्योंकि आंतरिक एक निचली परतों में चलता है। तो, क्यों नहीं preg_match()
? नियमित अभिव्यक्ति हर आंतरिक स्ट्रिंग हेरफेर फ़ंक्शन की तुलना में लगभग धीमी होती है, क्योंकि कई बार स्ट्रिंग में खोज करने के उनके राष्ट्र के कारण।
substr_replace($string, $replace, 0, strlen($search));
) पर बेंचमार्क ने केवल उस स्थिर को नहीं लिखा 0
। गैर-रेगेक्स समाधानों के दृढ़ विश्वास का हिस्सा यह है कि उन्हें यह जानने के लिए शुरुआती बिंदु को "खोजने" की आवश्यकता है कि कहां बदलना है।
दुर्भाग्य से, मुझे किसी भी PHP फ़ंक्शन का पता नहीं है जो ऐसा कर सकता है।
आप इस तरह से आसानी से अपना रोल कर सकते हैं:
function replace_first($find, $replace, $subject) {
// stolen from the comments at PHP.net/str_replace
// Splits $subject into an array of 2 items by $find,
// and then joins the array with $replace
return implode($replace, explode($find, $subject, 2));
}
return implode($replace, explode($find, $subject, $limit+1));
कस्टम रिप्लेस नंबरों के लिए
मैंने इस छोटे से फंक्शन को बनाया , जो रीगेक्सपी की आवश्यकता के बिना, स्ट्रिंग को (केस-संवेदी) सीमा के साथ बदल देता है। यह बढ़िया काम करता है।
function str_replace_limit($search, $replace, $string, $limit = 1) {
$pos = strpos($string, $search);
if ($pos === false) {
return $string;
}
$searchLen = strlen($search);
for ($i = 0; $i < $limit; $i++) {
$string = substr_replace($string, $replace, $pos, $searchLen);
$pos = strpos($string, $search);
if ($pos === false) {
break;
}
}
return $string;
}
उदाहरण का उपयोग:
$search = 'foo';
$replace = 'bar';
$string = 'foo wizard makes foo brew for evil foo and jack';
$limit = 2;
$replaced = str_replace_limit($search, $replace, $string, $limit);
echo $replaced;
// bar wizard makes bar brew for evil foo and jack
===false
के is_bool(
लिए करूँगा - मैं इस अंगूठे को सिर्फ इसलिए दे रहा हूं क्योंकि इसने RegExp पागलपन से बचा लिया है ! ... और एक ही समय में यह काम कर रहा है और स्वच्छ समाधान ...
preg_
समाधान का उल्लेख करना पागलपन नहीं बल्कि व्यक्तिगत प्राथमिकता है। return preg_replace('/'.preg_quote($search, '/').'/', $replace, $content, 1);
उन लोगों के लिए पढ़ना बहुत आसान है जो रेगेक्स से नहीं डरते। केस-असंवेदनशील खोज की आवश्यकता है? i
अंत पैटर्न सीमांकक के बाद जोड़ें । यूनिकोड / मल्टीबाइट समर्थन की आवश्यकता है? u
अंत पैटर्न सीमांकक के बाद जोड़ें । शब्द सीमा समर्थन की आवश्यकता है? \b
अपनी खोज स्ट्रिंग के दोनों किनारों पर जोड़ें । यदि आप रेगेक्स नहीं चाहते हैं, तो रेगेक्स का उपयोग न करें। पाठ्यक्रमों के लिए घोड़े, लेकिन निश्चित रूप से पागलपन नहीं।
function str_replace_once($search, $replace, $subject) {
$pos = strpos($subject, $search);
if ($pos === false) {
return $subject;
}
return substr($subject, 0, $pos) . $replace . substr($subject, $pos + strlen($search));
}
=> कोड की समीक्षा की गई, इसलिए कुछ टिप्पणियों को बहुत पुराना मानें
और उस सुधार के लिए मेरी मदद करने पर सभी को धन्यवाद
कोई बग, कृपया मुझे सूचित करें; मैं इसे ठीक कर दूँगा
तो, के लिए जाने देता है:
उदाहरण के लिए पहले 'o' को 'ea' में बदलना :
$s='I love you';
$s=str_replace_first('o','ea',$s);
echo $s;
//output: I leave you
कार्यक्रम:
function str_replace_first($a,$b,$s)
{
$w=strpos($s,$a);
if($w===false)return $s;
return substr($s,0,$w).$b.substr($s,$w+strlen($a));
}
substr($where,$b+strlen($this))
, नहीं substr($where,$b+1)
। और मुझे लगता है कि substr_replace
यह तेज है।
$string = 'this is my world, not my world';
$find = 'world';
$replace = 'farm';
$result = preg_replace("/$find/",$replace,$string,1);
echo $result;
preg_quote
से $find
पहले करना चाहिए ।
preg_quote()
। इस देर से नकली उत्तर को पृष्ठ से सुरक्षित रूप से शुद्ध किया जा सकता है क्योंकि इसकी सलाह पहले से प्रदान की गई है, और उच्चतर स्वीकृत स्वीकार किए जाते हैं।
@ रेनोकोर के उत्तर पर विस्तार करने के लिए , मैंने एक फ़ंक्शन लिखा है जो 100% पिछड़े-संगत है str_replace()
। यही कारण है कि आप की जगह ले सकता है, सभी की घटनाओं str_replace()
के साथ str_replace_limit()
के लिए यहां तक कि उन सरणियों का उपयोग कर कुछ भी खिलवाड़ के बिना, $search
, $replace
, और / या $subject
।
यदि आप फ़ंक्शन कॉल को बदलना चाहते हैं, तो फ़ंक्शन पूरी तरह से स्व-निहित हो सकता है ($string===strval(intval(strval($string))))
, लेकिन मैं इसके खिलाफ सिफारिश करूंगा valid_integer()
क्योंकि स्ट्रिंग्स के रूप में प्रदान किए गए पूर्णांकों के साथ काम करते समय यह एक उपयोगी फ़ंक्शन है।
नोट: जब भी संभव हो, इसके बजाय str_replace_limit()
का उपयोग करेगा str_replace()
, इसलिए सभी कॉल को एक हिट प्रदर्शन के बारे में चिंता किए बिना str_replace()
बदला जा सकता है str_replace_limit()
।
<?php
$search = 'a';
$replace = 'b';
$subject = 'abcabc';
$limit = -1; // No limit
$new_string = str_replace_limit($search, $replace, $subject, $count, $limit);
echo $count.' replacements -- '.$new_string;
2 प्रतिस्थापन - bbcbbc
$limit = 1; // Limit of 1
$new_string = str_replace_limit($search, $replace, $subject, $count, $limit);
echo $count.' replacements -- '.$new_string;
1 प्रतिस्थापन - bbcabc
$limit = 10; // Limit of 10
$new_string = str_replace_limit($search, $replace, $subject, $count, $limit);
echo $count.' replacements -- '.$new_string;
2 प्रतिस्थापन - bbcbbc
<?php
/**
* Checks if $string is a valid integer. Integers provided as strings (e.g. '2' vs 2)
* are also supported.
* @param mixed $string
* @return bool Returns boolean TRUE if string is a valid integer, or FALSE if it is not
*/
function valid_integer($string){
// 1. Cast as string (in case integer is provided)
// 1. Convert the string to an integer and back to a string
// 2. Check if identical (note: 'identical', NOT just 'equal')
// Note: TRUE, FALSE, and NULL $string values all return FALSE
$string = strval($string);
return ($string===strval(intval($string)));
}
/**
* Replace $limit occurences of the search string with the replacement string
* @param mixed $search The value being searched for, otherwise known as the needle. An
* array may be used to designate multiple needles.
* @param mixed $replace The replacement value that replaces found search values. An
* array may be used to designate multiple replacements.
* @param mixed $subject The string or array being searched and replaced on, otherwise
* known as the haystack. If subject is an array, then the search and replace is
* performed with every entry of subject, and the return value is an array as well.
* @param string $count If passed, this will be set to the number of replacements
* performed.
* @param int $limit The maximum possible replacements for each pattern in each subject
* string. Defaults to -1 (no limit).
* @return string This function returns a string with the replaced values.
*/
function str_replace_limit(
$search,
$replace,
$subject,
&$count,
$limit = -1
){
// Set some defaults
$count = 0;
// Invalid $limit provided. Throw a warning.
if(!valid_integer($limit)){
$backtrace = debug_backtrace();
trigger_error('Invalid $limit `'.$limit.'` provided to '.__function__.'() in '.
'`'.$backtrace[0]['file'].'` on line '.$backtrace[0]['line'].'. Expecting an '.
'integer', E_USER_WARNING);
return $subject;
}
// Invalid $limit provided. Throw a warning.
if($limit<-1){
$backtrace = debug_backtrace();
trigger_error('Invalid $limit `'.$limit.'` provided to '.__function__.'() in '.
'`'.$backtrace[0]['file'].'` on line '.$backtrace[0]['line'].'. Expecting -1 or '.
'a positive integer', E_USER_WARNING);
return $subject;
}
// No replacements necessary. Throw a notice as this was most likely not the intended
// use. And, if it was (e.g. part of a loop, setting $limit dynamically), it can be
// worked around by simply checking to see if $limit===0, and if it does, skip the
// function call (and set $count to 0, if applicable).
if($limit===0){
$backtrace = debug_backtrace();
trigger_error('Invalid $limit `'.$limit.'` provided to '.__function__.'() in '.
'`'.$backtrace[0]['file'].'` on line '.$backtrace[0]['line'].'. Expecting -1 or '.
'a positive integer', E_USER_NOTICE);
return $subject;
}
// Use str_replace() whenever possible (for performance reasons)
if($limit===-1){
return str_replace($search, $replace, $subject, $count);
}
if(is_array($subject)){
// Loop through $subject values and call this function for each one.
foreach($subject as $key => $this_subject){
// Skip values that are arrays (to match str_replace()).
if(!is_array($this_subject)){
// Call this function again for
$this_function = __FUNCTION__;
$subject[$key] = $this_function(
$search,
$replace,
$this_subject,
$this_count,
$limit
);
// Adjust $count
$count += $this_count;
// Adjust $limit, if not -1
if($limit!=-1){
$limit -= $this_count;
}
// Reached $limit, return $subject
if($limit===0){
return $subject;
}
}
}
return $subject;
} elseif(is_array($search)){
// Only treat $replace as an array if $search is also an array (to match str_replace())
// Clear keys of $search (to match str_replace()).
$search = array_values($search);
// Clear keys of $replace, if applicable (to match str_replace()).
if(is_array($replace)){
$replace = array_values($replace);
}
// Loop through $search array.
foreach($search as $key => $this_search){
// Don't support multi-dimensional arrays (to match str_replace()).
$this_search = strval($this_search);
// If $replace is an array, use the value of $replace[$key] as the replacement. If
// $replace[$key] doesn't exist, just an empty string (to match str_replace()).
if(is_array($replace)){
if(array_key_exists($key, $replace)){
$this_replace = strval($replace[$key]);
} else {
$this_replace = '';
}
} else {
$this_replace = strval($replace);
}
// Call this function again for
$this_function = __FUNCTION__;
$subject = $this_function(
$this_search,
$this_replace,
$subject,
$this_count,
$limit
);
// Adjust $count
$count += $this_count;
// Adjust $limit, if not -1
if($limit!=-1){
$limit -= $this_count;
}
// Reached $limit, return $subject
if($limit===0){
return $subject;
}
}
return $subject;
} else {
$search = strval($search);
$replace = strval($replace);
// Get position of first $search
$pos = strpos($subject, $search);
// Return $subject if $search cannot be found
if($pos===false){
return $subject;
}
// Get length of $search, to make proper replacement later on
$search_len = strlen($search);
// Loop until $search can no longer be found, or $limit is reached
for($i=0;(($i<$limit)||($limit===-1));$i++){
// Replace
$subject = substr_replace($subject, $replace, $pos, $search_len);
// Increase $count
$count++;
// Get location of next $search
$pos = strpos($subject, $search);
// Break out of loop if $needle
if($pos===false){
break;
}
}
// Return new $subject
return $subject;
}
}
E_USER_WARNING
भर है, जो एक है चेतावनी , नहीं एक त्रुटि । बैकट्रेस यह पता लगाने के लिए बेहद उपयोगी है कि पहली जगह में फ़ंक्शन के लिए अमान्य डेटा किस कोड से गुजर रहा है (जो उत्पादन में बग को ट्रैक करने के लिए बिल्कुल आवश्यक है)। के $subject
बजाय लौटने के बजाय false
/ null
या एक त्रुटि को फेंकने के लिए, यह बस मेरे उपयोग के मामले के लिए एक व्यक्तिगत विकल्प था। मैच के लिए str_replace()
की कार्यक्षमता, catchable घातक त्रुटियों का उपयोग कर सबसे अच्छा शर्त होगी (के रूप में str_replace()
जब पहली दो तर्क के लिए एक बंद प्रदान करता है)।
preg_replace()
। इसके अलावा, preg_replace()
/ regex शब्द सीमा हैंडलिंग (यदि वांछनीय है) प्रदान करता है - ऐसा कुछ जो गैर-रेगेक्स फ़ंक्शन सुरुचिपूर्ण ढंग से प्रदान नहीं करेगा।
अपने परीक्षा परिणाम के अनुसार, मैं karim79 द्वारा उपलब्ध कराए गए regular_express को वोट देना चाहूंगा। (मेरे पास अब इसे वोट करने के लिए पर्याप्त प्रतिष्ठा नहीं है!)
ज़ोम्बैट से समाधान कई फ़ंक्शन कॉल का उपयोग करता है, मैं कोड को भी सरल करता हूं। मैं PHP 5.4 का उपयोग 100,000 बार दोनों समाधानों को चलाने के लिए कर रहा हूँ, और यहाँ परिणाम है:
$str = 'Hello abc, have a nice day abc! abc!';
$pos = strpos($str, 'abc');
$str = substr_replace($str, '123', $pos, 3);
==> 1.85 सेकंड
$str = 'Hello abc, have a nice day abc! abc!';
$str = preg_replace('/abc/', '123', $str, 1);
==> 1.35 सेकंड
जैसा कि आप देख सकते हैं। Preg_replace का प्रदर्शन इतना बुरा नहीं है जितना कि कई लोग सोचते हैं। इसलिए मैं उत्तम दर्जे का समाधान सुझाता हूँ यदि आपका नियमित व्यक्त जटिल नहीं है।
$pos
लिए जाँच नहीं कर रहे हैं false
, इसलिए जब सुई अस्तित्व में नहीं है, यह उत्पादन को नुकसान होगा।
ज़ोम्बैट के उत्तर पर विस्तार करने के लिए (जिसे मैं सबसे अच्छा उत्तर मानता हूं), मैंने उनके फ़ंक्शन का एक पुनरावर्ती संस्करण तैयार किया जो $limit
यह निर्दिष्ट करने के लिए एक पैरामीटर में होता है कि आप कितनी जगह बदलना चाहते हैं।
function str_replace_limit($haystack, $needle, $replace, $limit, $start_pos = 0) {
if ($limit <= 0) {
return $haystack;
} else {
$pos = strpos($haystack,$needle,$start_pos);
if ($pos !== false) {
$newstring = substr_replace($haystack, $replace, $pos, strlen($needle));
return str_replace_limit($newstring, $needle, $replace, $limit-1, $pos+strlen($replace));
} else {
return $haystack;
}
}
}
$start_pos
, इसलिए यदि यह स्ट्रिंग की लंबाई से परे है, तो यह फ़ंक्शन उत्पन्न करेगा Warning: strpos(): Offset not contained in string...
:। $start_pos
लंबाई से परे होने पर यह फ़ंक्शन प्रतिस्थापन करने में विफल रहता है । असफलता का प्रमाण: 3v4l.org/qGuVIR ... आपका फ़ंक्शन return $haystack
शर्तों को संयोजित कर सकता है और इस तरह के एकल-उपयोग चर घोषित करने से बच सकता है: 3v4l.org/Kdmqp हालाँकि, जैसा कि मैंने इस पृष्ठ पर अन्य टिप्पणियों में कहा है, मैं चाहूँगा एक बहुत साफ, प्रत्यक्ष, गैर-पुनरावर्ती preg_replace()
कॉल का उपयोग करें।
else
बयान$start_pos > strlen($haystack) ? $start_pos = strlen($haystack) : '';
एक तार के लिए
$string = 'OOO.OOO.OOO.S';
$search = 'OOO';
$replace = 'B';
//replace ONLY FIRST occurance of "OOO" with "B"
$string = substr_replace($string,$replace,0,strlen($search));
//$string => B.OOO.OOO.S
//replace ONLY LAST occurance of "OOOO" with "B"
$string = substr_replace($string,$replace,strrpos($string,$search),strlen($search))
//$string => OOO.OOO.B.S
//replace ONLY LAST occurance of "OOOO" with "B"
$string = strrev(implode(strrev($replace),explode(strrev($search),strrev($string),2)))
//$string => OOO.OOO.B.S
एकल चरित्र के लिए
$string[strpos($string,$search)] = $replace;
//EXAMPLE
$string = 'O.O.O.O.S';
$search = 'O';
$replace = 'B';
//replace ONLY FIRST occurance of "O" with "B"
$string[strpos($string,$search)] = $replace;
//$string => B.O.O.O.S
//replace ONLY LAST occurance of "O" with "B"
$string[strrpos($string,$search)] = $replace;
// $string => B.O.O.B.S
substr_replace()
तकनीक इनपुट स्ट्रिंग को नुकसान पहुंचाती हैं जब खोज मूल्य मौजूद नहीं होता है। विफलता का प्रमाण: 3v4l.org/HmEml (और आख़िरी तकनीक के साथ आख़िरी तकनीक rev
को गंभीरता से आंखों पर
लोगों ने जो कहा, उसे लागू करते हुए याद रखें कि संपूर्ण स्ट्रिंग एक सरणी है:
$string = "Lorem ipsum lá lá lá";
$string[0] = "B";
echo $string;
"बोरम इप्सम ला ला ला"
á
। विफलता का प्रदर्शन
string
मल्टीबाइट स्ट्रिंग का उपयोगmb_strlen($subject) != strlen($subject)
$str = "/property/details&id=202&test=123#tab-6p";
$position = strpos($str,"&");
echo substr_replace($str,"?",$position,1);
Root_replace का उपयोग करके हम पहले वर्ण की घटना को केवल स्ट्रिंग में बदल सकते हैं। के रूप में और कई बार दोहराया जाता है, लेकिन केवल पहली स्थिति में हमें प्रतिस्थापित करना होगा?
यह समारोह @renocor के जवाब से काफी प्रेरित है। यह फ़ंक्शन मल्टी बाइट को सुरक्षित बनाता है।
function str_replace_limit($search, $replace, $string, $limit)
{
$i = 0;
$searchLength = mb_strlen($search);
while(($pos = mb_strpos($string, $search)) !== false && $i < $limit)
{
$string = mb_substr_replace($string, $replace, $pos, $searchLength);
$i += 1;
}
return $string;
}
function mb_substr_replace($string, $replacement, $start, $length = null, $encoding = null)
{
$string = (array)$string;
$encoding = is_null($encoding) ? mb_internal_encoding() : $encoding;
$length = is_null($length) ? mb_strlen($string) - $start : $length;
$string = array_map(function($str) use ($replacement, $start, $length, $encoding){
$begin = mb_substr($str, 0, $start, $encoding);
$end = mb_substr($str, ($start + $length), mb_strlen($str), $encoding);
return $begin . $replacement . $end;
}, $string);
return ( count($string) === 1 ) ? $string[0] : $string;
}
आप इसका उपयोग कर सकते हैं:
function str_replace_once($str_pattern, $str_replacement, $string){
if (strpos($string, $str_pattern) !== false){
$occurrence = strpos($string, $str_pattern);
return substr_replace($string, $str_replacement, strpos($string, $str_pattern), strlen($str_pattern));
}
return $string;
}
इसका उदाहरण php.net से मिला
उपयोग:
$string = "Thiz iz an examplz";
var_dump(str_replace_once('z','Z', $string));
आउटपुट:
ThiZ iz an examplz
यह प्रदर्शन को थोड़ा कम कर सकता है, लेकिन सबसे आसान समाधान।
strpos()
) पेश किया था। डाउनवोट किया गया क्योंकि यह पृष्ठ पर कोई नया मान नहीं जोड़ता है।
यदि आप स्ट्रिंग में कोई मल्टीबाइट वर्ण नहीं है और यदि आप केवल एक चार को बदलना चाहते हैं तो आप बस उपयोग कर सकते हैं strpos
यहां एक फ़ंक्शन जो त्रुटियों को संभालता है
/**
* Replace the first occurence of given string
*
* @param string $search a char to search in `$subject`
* @param string $replace a char to replace in `$subject`
* @param string $subject
* @return string
*
* @throws InvalidArgumentException if `$search` or `$replace` are invalid or if `$subject` is a multibytes string
*/
function str_replace_first(string $search , string $replace , string $subject) : string {
// check params
if(strlen($replace) != 1 || strlen($search) != 1) {
throw new InvalidArgumentException('$search & $replace must be char');
}elseif(mb_strlen($subject) != strlen($subject)){
throw new InvalidArgumentException('$subject is an multibytes string');
}
// search
$pos = strpos($subject, $search);
if($pos === false) {
// not found
return $subject;
}
// replace
$subject[$replace] = $subject;
return $subject;
}
लूप सॉल्यूशन के लिए
<?php
echo replaceFirstMatchedChar("&", "?", "/property/details&id=202&test=123#tab-6");
function replaceFirstMatchedChar($searchChar, $replaceChar, $str)
{
for ($i = 0; $i < strlen($str); $i++) {
if ($str[$i] == $searchChar) {
$str[$i] = $replaceChar;
break;
}
}
return $str;
}
यहाँ एक साधारण वर्ग है जो मैंने हमारे थोड़े संशोधित str_replace () को लपेटने के लिए बनाया है फ़ंक्शन ।
हमारा php :: str_rreplace () फ़ंक्शन भी आपको एक रिवर्स, सीमित str_replace () को बाहर ले जाने की अनुमति देता है जो स्ट्रिंग के केवल अंतिम X उदाहरण (s) को बदलने की कोशिश करते समय बहुत आसान हो सकता है।
ये उदाहरण दोनों preg_replace () का उपयोग करते हैं ।
<?php
class php {
/**
* str_replace() from the end of a string that can also be limited e.g. replace only the last instance of '</div>' with ''
*
* @param string $find
* @param string $replace
* @param string $subject
* @param int $replacement_limit | -1 to replace all references
*
* @return string
*/
public static function str_replace($find, $replace, $subject, $replacement_limit = -1) {
$find_pattern = str_replace('/', '\/', $find);
return preg_replace('/' . $find_pattern . '/', $replace, $subject, $replacement_limit);
}
/**
* str_replace() from the end of a string that can also be limited e.g. replace only the last instance of '</div>' with ''
*
* @param string $find
* @param string $replace
* @param string $subject
* @param int $replacement_limit | -1 to replace all references
*
* @return string
*/
public static function str_rreplace($find, $replace, $subject, $replacement_limit = -1) {
return strrev( self::str_replace(strrev($find), strrev($replace), strrev($subject), $replacement_limit) );
}
}
$str = "Hello there folks!"
$str_ex = explode("there, $str, 2); //explodes $string just twice
//outputs: array ("Hello ", " folks")
$str_final = implode("", $str_ex); // glues above array together
// outputs: str("Hello folks")
एक और अतिरिक्त जगह है, लेकिन मेरे मामले में बैकगाउंड स्क्रिप्ट के लिए यह महत्वपूर्ण नहीं था।
यह मेरा पहला उत्तर है, मैं इसे सही ढंग से करने की उम्मीद करता हूं। इस समस्या के लिए str_replace फ़ंक्शन के चौथे तर्क का उपयोग क्यों नहीं किया जाता है?
mixed str_replace ( mixed $search , mixed $replace , mixed $subject [, int &$count ] )
गणना: यदि पारित किया जाता है, तो यह प्रदर्शन किए गए प्रतिस्थापनों की संख्या पर सेट किया जाएगा।
संपादित करें: यह उत्तर गलत है, क्योंकि str_replace का 4th पैरामीटर एक चर है जिसे किए गए प्रतिस्थापनों की संख्या असाइन की गई है। यह preg_replace के साथ असंगत है , जिसका 4 $limit
वाँ पैरामीटर और 5 वाँ पैरामीटर है &$count
।
केवल पहले या पहले कुछ उदाहरणों को बदलने के लिए एक समाधान खोजना आसान है (गणना मूल्य देकर)। उदाहरण के अंतिम या अंतिम जोड़े को बदलने के लिए कई समाधान नहीं हैं।
शायद str_replace ($ खोज, $ प्रतिस्थापित, $ विषय, -3) जैसी कुछ चीज़ों को अंतिम तीन उदाहरणों को बदलना चाहिए।
वैसे भी, सिर्फ एक सुझाव।
s($subject)->replaceFirst($search)
औरs($subject)->replaceFirstIgnoreCase($search)
उपयोगी मान सकते हैं ।