|  | 
 
 
  substrReturn part of a string 
  Description
   string substr(string $string, int$offset, intnull$length=null) 
  Parameters
    
    
     
string
      
       The input string.
      
offset
      
       If offsetis non-negative, the returned string
       will start at theoffset'th position instring, counting from zero. For instance,
       in the string 'abcdef', the character at
       position0is 'a', the
       character at position2is
       'c', and so forth. 
       If offsetis negative, the returned string
       will start at theoffset'th character
       from the end ofstring. 
       If stringis less thanoffsetcharacters long, an empty string will be returned. 
        
        Example #1 Using a negative offset 
<?php
echo substr("abcdef", -1), PHP_EOL;    // returns "f"
echo substr("abcdef", -2), PHP_EOL;    // returns "ef"
echo substr("abcdef", -3, 1), PHP_EOL; // returns "d"
?>
length
      
       If lengthis given and is positive, the string
       returned will contain at mostlengthcharacters
       beginning fromoffset(depending on the length ofstring). 
       If lengthis given and is negative, then that many
       characters will be omitted from the end ofstring.
       Ifoffsetdenotes the position of this truncation or
       beyond, an empty string will be returned. 
       If lengthis given and is0,
       an empty string will be returned. 
       If lengthis omitted ornull, the substring starting fromoffsetuntil the end of the string will be
       returned. 
       Example #2 Using a negative length 
<?php
echo substr("abcdef", 0, -1), PHP_EOL;  // returns "abcde"
echo substr("abcdef", 2, -1), PHP_EOL;  // returns "cde"
echo substr("abcdef", 4, -4), PHP_EOL;  // returns ""; prior to PHP 8.0.0, false was returned
echo substr("abcdef", -3, -1), PHP_EOL; // returns "de"
?>
 
  Return Values
   Returns the extracted part of string, or
   an empty string. 
  Examples
    
    Example #3 Basic substr usage 
<?php
echo substr('abcdef', 1), PHP_EOL;     // bcdef
echo substr("abcdef", 1, null), PHP_EOL; // bcdef; prior to PHP 8.0.0, empty string was returned
echo substr('abcdef', 1, 3), PHP_EOL;  // bcd
echo substr('abcdef', 0, 4), PHP_EOL;  // abcd
echo substr('abcdef', 0, 8), PHP_EOL;  // abcdef
echo substr('abcdef', -1, 1), PHP_EOL; // f
// Accessing single characters in a string
// can also be achieved using "square brackets"
$string = 'abcdef';
echo $string[0], PHP_EOL;                 // a
echo $string[3], PHP_EOL;                 // d
echo $string[strlen($string)-1], PHP_EOL; // f
?>
 
    Example #4 substr casting behaviour 
<?php
class apple {
    public function __toString() {
        return "green";
    }
}
echo "1) ", var_export(substr("pear", 0, 2), true), PHP_EOL;
echo "2) ", var_export(substr(54321, 0, 2), true), PHP_EOL;
echo "3) ", var_export(substr(new apple(), 0, 2), true), PHP_EOL;
echo "4) ", var_export(substr(true, 0, 1), true), PHP_EOL;
echo "5) ", var_export(substr(false, 0, 1), true), PHP_EOL;
echo "6) ", var_export(substr("", 0, 1), true), PHP_EOL;
echo "7) ", var_export(substr(1.2e3, 0, 4), true), PHP_EOL;
?>
 The above example will output:
1) 'pe'
2) '54'
3) 'gr'
4) '1'
5) ''
6) ''
7) '1200'
 
   Example #5 Invalid Character Range 
    If an invalid character range is requested, substr returns
    an empty string as of PHP 8.0.0; previously, falsewas returned instead.
<?php
var_dump(substr('a', 2));
?>
 Output of the above example in PHP 8:Output of the above example in PHP 7: |