You are here: Perldoc Web>Perlfunc_substr (2003-08-23)
       substr EXPR,OFFSET,LENGTH,REPLACEMENT
       substr EXPR,OFFSET,LENGTH
       substr EXPR,OFFSET
               Extracts a substring out of EXPR and returns it.
               First character is at offset 0, or whatever you've
               set $[ to (but don't do that).  If OFFSET is nega-
               tive (or more precisely, less than $[), starts
               that far from the end of the string.  If LENGTH is
               omitted, returns everything to the end of the
               string.  If LENGTH is negative, leaves that many
               characters off the end of the string.

               You can use the substr() function as an lvalue, in
               which case EXPR must itself be an lvalue.  If you
               assign something shorter than LENGTH, the string
               will shrink, and if you assign something longer
               than LENGTH, the string will grow to accommodate
               it.  To keep the string the same length you may
               need to pad or chop your value using "sprintf".

               If OFFSET and LENGTH specify a substring that is
               partly outside the string, only the part within
               the string is returned.  If the substring is
               beyond either end of the string, substr() returns
               it.  To keep the string the same length you may
               need to pad or chop your value using "sprintf".

               If OFFSET and LENGTH specify a substring that is
               partly outside the string, only the part within
               the string is returned.  If the substring is
               beyond either end of the string, substr() returns
               the undefined value and produces a warning.  When
               used as an lvalue, specifying a substring that is
               entirely outside the string is a fatal error.
               Here's an example showing the behavior for bound-
               ary cases:

                   my $name = 'fred';
                   substr($name, 4) = 'dy';            # $name is now 'freddy'
                   my $null = substr $name, 6, 2;      # returns '' (no warning)
                   my $oops = substr $name, 7;         # returns undef, with warning
                   substr($name, 7) = 'gap';           # fatal error

               An alternative to using substr() as an lvalue is
               to specify the replacement string as the 4th argu-
               ment.  This allows you to replace parts of the
               EXPR and return what was there before in one oper-
               ation, just as you can with splice().

Ja, noch sehr un-deutsch...

-- RelaiS - 23 Aug 2003
Topic revision: 2003-08-23, RelaiS
 
Bitte die NutzungsBedingungen beachten.
Bei Vorschlägen, Anfragen oder Problemen mit dem PerlCommunityWiki bitten wir um WebBottomBarExample">Rückmeldung.