Las funciones de cadena se utilizan en lenguajes de programación informática para manipular una cadena o consultar información sobre una cadena (algunas hacen ambas cosas).
La mayoría de los lenguajes de programación que tienen un tipo de datos de cadena tendrán algunas funciones de cadena, aunque puede haber otras formas de bajo nivel dentro de cada lenguaje para manejar cadenas directamente. En los lenguajes orientados a objetos, las funciones de cadena se implementan a menudo como propiedades y métodos de objetos de cadena. En los lenguajes funcionales y basados en listas, una cadena se representa como una lista (de códigos de caracteres), por lo tanto, todos los procedimientos de manipulación de listas podrían considerarse funciones de cadena. Sin embargo, dichos lenguajes también pueden implementar un subconjunto de funciones explícitas específicas de cadenas.
En el caso de las funciones que manipulan cadenas, los lenguajes modernos orientados a objetos, como C# y Java , tienen cadenas inmutables y devuelven una copia (en la memoria dinámica recién asignada), mientras que otros, como C, manipulan la cadena original a menos que el programador copie los datos en una nueva cadena. Véase, por ejemplo, la concatenación a continuación.
El ejemplo más básico de una función de cadena es la length(string)
función . Esta función devuelve la longitud de un literal de cadena .
length("hello world")
devolvería 11.Otros lenguajes pueden tener funciones de cadena con sintaxis, parámetros o resultados similares o exactamente iguales. Por ejemplo, en muchos lenguajes la función length suele representarse como len(string) . La siguiente lista de funciones comunes tiene como objetivo ayudar a limitar esta confusión.
A continuación se enumeran las funciones de cadena comunes a muchos lenguajes, incluidos los diferentes nombres utilizados. La siguiente lista de funciones comunes tiene como objetivo ayudar a los programadores a encontrar la función equivalente en un lenguaje. Tenga en cuenta que la concatenación de cadenas y las expresiones regulares se manejan en páginas separadas. Las declaraciones entre guillemets (« … ») son opcionales.
{ Ejemplo en Pascal } var MyStr : string = 'Hola, mundo' ; MyChar : Char ; begin MyChar := MyStr [ 2 ] ; // 'e'
# Ejemplo en ALGOL 68 #"Hola, mundo"[2]; // 'e'
// Ejemplo en C #include <stdio.h> // para printf char MyStr [] = "Hola, mundo" ; printf ( "%c" , * ( MyStr + 1 )); // 'e' printf ( "%c" , * ( MyStr + 7 )); // 'W' printf ( "%c" , MyStr [ 11 ]); // 'd' printf ( "%s" , MyStr ); // 'Hola, mundo' printf ( "%s" , "Hola(2), Mundo(2)" ); // 'Hola(2), Mundo(2)'
// Ejemplo en C++ #include <iostream> // para "cout" #include <string.h> // para el tipo de datos "string" que utiliza el espacio de nombres std ; char MyStr1 [] = "Hola(1), Mundo(1)" ; string MyStr2 = "Hola(2), Mundo(2)" ; cout << "Hola(3), Mundo(3)" ; // 'Hola(3), Mundo(3)' cout << MyStr2 [ 6 ]; // '2' cout << MyStr1 . substr ( 5 , 3 ); // '(1)'
// Ejemplo en C# "Hola, mundo" [ 2 ]; // 'l'
# Ejemplo en Perl 5 substr ( "Hola, Mundo" , 1 , 1 ); # 'e'
# Ejemplos en Python "Hola, mundo" [ 2 ] # 'l' "Hola, mundo" [ - 3 ] # 'r'
# Ejemplo en Raku "Hola, mundo" . substr ( 1 , 1 ); # 'e'
' Ejemplo en Visual Basic Mid ( "Hola, mundo" , 2 , 1 )
' Ejemplo en Visual Basic .NET "Hola, mundo" . Caracteres ( 2 ) ' "l"c
" Ejemplo en Smalltalk " 'Hola, mundo' en: 2 . "$e"
//Ejemplo en Rust "Hola, mundo" . chars (). nth ( 2 ); // Some('l')
# Ejemplo en Perl 5 "hola" cmp "mundo" ; # devuelve -1
# Ejemplo en Python cmp ( "hola" , "mundo" ) # devuelve -1
# Ejemplos en Raku "hola" cmp "mundo" ; # devuelve Menos "mundo" cmp "hola" ; # devuelve Más "hola" cmp "hola" ; # devuelve Igual
/** Ejemplo en Rexx */ compare ( "hola" , "mundo" ) /* devuelve el índice de desajuste: 1 */
; Ejemplo en Scheme ( use-modules ( srfi srfi-13 )) ; devuelve el índice de desajuste: 0 ( string-compare "hello" "world" values values values )
% Ejemplo en Erlang "hola" > "mundo" . % devuelve falso
# Ejemplo en Raku "arte" gt "pintura" ; # devuelve Falso "arte" lt "pintura" ; # devuelve Verdadero
# Ejemplo en Windows PowerShell "hello" -gt "world" # devuelve falso
;; Ejemplo en Common Lisp ( cadena> "arte" "pintura" ) ; devuelve nil ( cadena< "arte" "pintura" ) ; devuelve un valor distinto de nil
{ Ejemplo en Pascal } 'abc' + 'def' ; // devuelve "abcdef"
// Ejemplo en C# "abc" + "def" ; // devuelve "abcdef"
' Ejemplo en Visual Basic "abc" & "def" ' devuelve "abcdef" "abc" + "def" ' devuelve "abcdef" "abc" & Null ' devuelve "abc" "abc" + Null ' devuelve Null
// Ejemplo en D "abc" ~ "def" ; // devuelve "abcdef"
;; Ejemplo en Common Lisp ( concatenar 'string "abc " "def " "ghi" ) ; devuelve "abc def ghi"
# Ejemplo en Perl 5 "abc" . "def" ; # devuelve "abcdef" "Perl " . 5 ; # devuelve "Perl 5"
# Ejemplo en Raku "abc" ~ "def" ; # devuelve "abcdef" "Perl " ~ 6 ; # devuelve "Perl 6"
¢ Ejemplo en ALGOL 68 ¢cadena en cadena ("e", loc int , "Hola amigo"); ¢ devuelve verdadero ¢cadena en cadena ("z", loc int , "palabra"); ¢ devuelve falso ¢
// Ejemplo En C# "Hola amigo" . Contiene ( "e" ); // devuelve verdadero "palabra" . Contiene ( "z" ); // devuelve falso
# Ejemplo en Python "e" en "Hola amigo" # devuelve verdadero "z" en "palabra" # devuelve falso
# Ejemplo en Raku "¡Buenos días!" . contiene ( 'z' ) # devuelve Falso "¡Buenos días!" . contiene ( 'í' ); # devuelve Verdadero
" Ejemplo en Smalltalk " 'Hola amigo' incluye Substring: 'e' " devuelve verdadero " ' palabra ' incluye Substring: 'z' " devuelve falso "
Comprueba si dos cadenas son iguales. Consulte también #Compare y #Compare. Tenga en cuenta que realizar comprobaciones de igualdad mediante una comparación genérica con un resultado entero no solo es confuso para el programador, sino que a menudo es una operación significativamente más costosa; esto es especialmente cierto cuando se utilizan " cadenas C ".
// Ejemplo en C# "hola" == "mundo" // devuelve falso
' Ejemplo en Visual Basic "hola" = "mundo" ' devuelve falso
# Ejemplos en Perl 5 'hola' eq 'mundo' # devuelve 0 'hola' eq 'hola' # devuelve 1
# Ejemplos en Raku 'hola' eq 'mundo' # devuelve Falso 'hola' eq 'hola' # devuelve Verdadero
# Ejemplo en Windows PowerShell "hello" -eq "world" # devuelve falso
⍝ Ejemplo en APL 'hola' ≡ 'mundo' ⍝ devuelve 0
Ejemplos
( buscar "e" "Hola amigo" ) ; devuelve 1 ( buscar "z" "palabra" ) ; devuelve NIL
"Hola amigo" . IndexOf ( "e" ); // devuelve 1 "Hola amigo" . IndexOf ( "e" , 4 ); // devuelve 9 "palabra" . IndexOf ( "z" ); // devuelve -1
"¡Hola!" . index ( 'e' ) # devuelve 1 "¡Hola!" . index ( 'z' ) # devuelve Nil
( use-modules ( srfi srfi-13 )) ( string-contains "Hola amigo" "e" ) ; devuelve 1 ( string-contains "word" "z" ) ; devuelve #f
' Ejemplos en InStr ( "Hola amigo" , "e" ) ' devuelve 2 InStr ( 5 , "Hola amigo" , "e" ) ' devuelve 10 InStr ( "palabra" , "z" ) ' devuelve 0
'Hola amigo' indexOfSubCollection: 'ate' "devuelve 8"
"Hola amigo" indexOfSubCollection: "tarde" "devuelve 0"
Hola amigo indexOfSubCollection : 'tarde' ifAbsent: [ 99 ] " devuelve 99 "
'Hola amigo' indexOfSubCollection: 'tarde' ifAbsent: [ error propio ] "genera una excepción"
// Ejemplos en C# "Hola amigo" . IndexOf ( 'e' ); // devuelve 1 "palabra" . IndexOf ( 'z' ) // devuelve -1
; Ejemplos en Common Lisp ( posición #\e "Hola amigo" ) ; devuelve 1 ( posición #\z "palabra" ) ; devuelve NIL
^a Dado un conjunto de caracteres, SCAN devuelve la posición del primer carácter encontrado, [19] mientras que VERIFY devuelve la posición del primer carácter que no pertenece al conjunto. [20]
// Ejemplo en C# String . Format ( "Mi {0} cuesta {1:C2}" , "bolígrafo" , 19,99 ); // devuelve "Mi bolígrafo cuesta $19,99"
// Ejemplo en formato Object Pascal (Delphi) ( 'Mi %s cuesta $%2f' , [ 'bolígrafo' , 1 9,99 ]) ; // devuelve "Mi bolígrafo cuesta $19,99"
// Ejemplo en Java String . format ( "Mi %s cuesta $%2f" , "bolígrafo" , 19,99 ); // devuelve "Mi bolígrafo cuesta $19,99"
# Ejemplos en Raku sprintf "Mi %s cuesta \$%.2f" , "bolígrafo" , 19.99 ; # devuelve "Mi bolígrafo cuesta $19.99" 1 . fmt ( "%04d" ); # devuelve "0001"
# Ejemplo en Python "Mi %s cuesta $ %.2f " % ( "bolígrafo" , 19.99 ); # devuelve "Mi bolígrafo cuesta $19.99" "Mi {0} cuesta $ {1:.2f} " . format ( "bolígrafo" , 19.99 ); # devuelve "Mi bolígrafo cuesta $19.99"
#Ejemplo en Python 3.6+ pen = "pen" f "Mi { pen } cuesta { 19,99 } " #devuelve "Mi bolígrafo cuesta 19,99"
; Ejemplo en Scheme ( formato "Mi ~a cuesta $~1,2F" "pluma" 19,99 ) ; devuelve "Mi pluma cuesta $19,99"
/* ejemplo en PL/I */ put string ( some_string ) edit ( ' Mi ' , ' bolígrafo ' , ' cuesta ' , 19.99 )( a , a , a , p ' $$$V .99 ' ) /* devuelve "Mi bolígrafo cuesta $19.99" */
Comprueba si dos cadenas no son iguales. Véase también #Igualdad.
// Ejemplo en C# "hola" != "mundo" // devuelve verdadero
' Ejemplo en Visual Basic "hola" <> "mundo" ' devuelve verdadero
;; Ejemplo en Clojure ( not= "hola" "mundo" ) ; ⇒ verdadero
# Ejemplo en Perl 5 'hola' ne 'mundo' # devuelve 1
# Ejemplo en Raku 'hola' y 'mundo' # devuelve Verdadero
# Ejemplo en Windows PowerShell "hola" -ne "mundo" # devuelve verdadero
ver #Encontrar
ver #Encontrar
ver #Encontrar
ver #rfind
// Ejemplo en C# String . Join ( "-" , { "a" , "b" , "c" }) // "abc"
" Ejemplo en Smalltalk " #( 'a' 'b' 'c' ) joinUsing: '-' " 'abc' "
# Ejemplo en Perl 5 join ( '-' , ( 'a' , 'b' , 'c' )); # 'abc'
# Ejemplo en Raku <ab c> . join ( '-' ); # 'abc'
# Ejemplo en Python "-" . join ([ "a" , "b" , "c" ]) # 'abc'
# Ejemplo en Ruby [ "a" , "b" , "c" ]. join ( "-" ) # 'abc'
; Ejemplo en Scheme ( use-modules ( srfi srfi-13 )) ( string-join ' ( "a" "b" "c" ) "-" ) ; "abc"
ver #rfind
# Ejemplo en Raku "¡Hola!" . substr ( 0 , 6 ); # devuelve "Hola".
/* Ejemplos en Rexx */ izquierda ( "abcde" , 3 ) /* devuelve "abc" */ izquierda ( "abcde" , 8 ) /* devuelve "abcde " */ izquierda ( "abcde" , 8 , "*" ) /* devuelve "abcde***" */
; Ejemplos en Scheme ( use-modules ( srfi srfi-13 )) ( string-take "abcde" , 3 ) ; devuelve "abc" ( string-take "abcde" , 8 ) ; error
' Ejemplos en Visual Basic Izquierda ( "sandroguidi" , 3 ) ' devuelve "san" Izquierda ( "sandroguidi" , 100 ) ' devuelve "sandroguidi"
ver #longitud
// Ejemplos en C# "hola" . Longitud ; // devuelve 5 "" . Longitud ; // devuelve 0
# Ejemplos en Erlang string : len ( "hola" ). % devuelve 5 string : len ( "" ). % devuelve 0
# Ejemplos en Perl 5 length ( "hola" ); # devuelve 5 length ( "" ); # devuelve 0
# Ejemplos en Raku "🏳️🌈" . chars ; chars "🏳️🌈" ; # ambos devuelven 1 "🏳️🌈" . codes ; codes "🏳️🌈" ; # ambos devuelven 4 "" . chars ; chars "" ; # ambos devuelven 0 "" . codes ; codes "" ; # ambos devuelven 0
' Ejemplos en Visual Basic Len ( "hola" ) ' devuelve 5 Len ( "" ) ' devuelve 0
//Ejemplos en Objective-C [ @"hello" Length ] //devuelve 5 [ @"" Length ] //devuelve 0
-- Ejemplos en Lua ( "hola" ): len () -- devuelve 5 # "" -- devuelve 0
ver #Encontrar
// Ejemplo en C# "¿Wiki significa rápido?" . ToLower (); // "¿wiki significa rápido?"
; Ejemplo en Scheme ( use-modules ( srfi srfi-13 )) ( string-downcase "Wiki significa rápido?" ) ; "¿wiki significa rápido?"
/* Ejemplo en C */ #include <ctype.h> #include <stdio.h> int main ( void ) { char string [] = "¿Wiki significa rápido?" ; int i ; for ( i = 0 ; i < sizeof ( string ) - 1 ; ++ i ) { /* transformar caracteres en su lugar, uno por uno */ string [ i ] = tolower ( string [ i ]); } puts ( string ); /* "¿Wiki significa rápido?" */ return 0 ; }
# Ejemplo en Raku "¿Wiki significa rápido?" . lc ; # "¿wiki significa rápido?"
ver #substring
# Ejemplos en Python "Huevos de spam, spam, spam y jamón" .partition ( 'spam' ) #('Huevos de spam', 'spam', 'spam y jamón') " Huevos de spam, spam, spam y jamón" .partition ( ' X' ) #('Huevos de spam, spam, spam y jamón', "", "")
# Ejemplos en Perl 5 / Raku split /(spam)/ , 'Huevos de spam, spam, spam y jamón' , 2 ; # ('Huevos de spam ', 'spam', ' spam y jamón'); split /(X)/ , 'Huevos de spam, spam, spam y jamón' , 2 ; # ('Huevos de spam, spam, spam y jamón');
// Ejemplos en C# "effffff" . Reemplazar ( "f" , "jump" ); // devuelve "ejumpjumpjumpjumpjumpjump" "blah" . Reemplazar ( "z" , "y" ); // devuelve "blah"
// Ejemplos en Java "effffff" . replace ( "f" , "jump" ); // devuelve "ejumpjumpjumpjumpjumpjump" "effffff" . replaceAll ( "f*" , "jump" ); // devuelve "ejump"
// Ejemplos en Raku "effffff" . subst ( "f" , "jump" , : g ); # devuelve "ejumpjumpjumpjumpjumpjump" "blah" . subst ( "z" , "y" , : g ); # devuelve "blah"
' Ejemplos en Visual Basic Reemplazar ( "effffff" , "f" , "jump" ) ' devuelve "ejumpjumpjumpjumpjumpjump" Reemplazar ( "blah" , "z" , "y" ) ' devuelve "blah"
# Ejemplos en Windows PowerShell "effffff" -replace "f" , "jump" # devuelve "ejumpjumpjumpjumpjumpjump" "effffff" -replace "f*" , "jump" # devuelve "ejump"
" Ejemplo en Smalltalk " 'hola' invertido " devuelve 'olleh' "
# Ejemplo en Perl 5 que invierte "hola" # devuelve "olleh"
# Ejemplo en Raku "hola" . flip # devuelve "olleh"
# Ejemplo en Python "hola" [:: - 1 ] # devuelve "olleh"
; Ejemplo en Scheme ( use-modules ( srfi srfi-13 )) ( string-reverse "hola" ) ; devuelve "olleh"
; Ejemplos en Common Lisp ( buscar "e" "Hola amigo" :from-end t ) ; devuelve 9 ( buscar "z" "palabra" :from-end t ) ; devuelve NIL
// Ejemplos en C# "Hola amigo" . LastIndexOf ( "e" ); // devuelve 9 "Hola amigo" . LastIndexOf ( "e" , 4 ); // devuelve 1 "palabra" . LastIndexOf ( "z" ); // devuelve -1
# Ejemplos en Perl 5 rindex ( "Hola amigo" , "e" ); # devuelve 9 rindex ( "Hola amigo" , "e" , 4 ); # devuelve 1 rindex ( "palabra" , "z" ); # devuelve -1
# Ejemplos en Raku "Hola amigo" . rindex ( "e" ); # devuelve 9 "Hola amigo" . rindex ( "e" , 4 ); # devuelve 1 "palabra" . rindex ( 'z' ); # devuelve Nil
' Ejemplos en Visual Basic InStrRev ( "Hola amigo" , "e" ) ' devuelve 10 InStrRev ( 5 , "Hola amigo" , "e" ) ' devuelve 2 InStrRev ( "word" , "z" ) ' devuelve 0
// Ejemplos en Java; extrae los 4 caracteres más a la derecha String str = "CarDoor" ; str . substring ( str . length () - 4 ); // devuelve 'Door'
# Ejemplos en Raku "abcde" . substr (*- 3 ); # devuelve "cde" "abcde" . substr (*- 8 ); # error 'fuera de rango'
/* Ejemplos en Rexx */ derecha ( "abcde" , 3 ) /* devuelve "cde" */ derecha ( "abcde" , 8 ) /* devuelve " abcde" */ derecha ( "abcde" , 8 , "*" ) /* devuelve "***abcde" */
; Ejemplos en Scheme ( use-modules ( srfi srfi-13 )) ( string-take-right "abcde" , 3 ) ; devuelve "cde" ( string-take-right "abcde" , 8 ) ; error
' Ejemplos en Visual Basic Derecha ( "sandroguidi" , 3 ) ' devuelve "idi" Derecha ( "sandroguidi" , 100 ) ' devuelve "sandroguidi"
# Ejemplos en Python "Huevos de spam, spam, spam y jamón" . rpartition ( 'spam' ) ### ('Huevos de spam, spam ', 'spam', ' y jamón') "Huevos de spam, spam, spam y jamón" . rpartition ( 'X' ) ### ("", "", 'Huevos de spam, spam, spam y jamón')
ver #substring
// Ejemplo en C# "abc,defgh,ijk" . Split ( ',' ); // {"abc", "defgh", "ijk"} "abc,defgh;ijk" . Split ( ',' , ';' ); // {"abc", "defgh", "ijk"}
% Ejemplo en cadena Erlang : tokens ( "abc;defgh;ijk" , ";" ). % ["abc", "defgh", "ijk"]
// Ejemplos en Java "abc,defgh,ijk" .split ( "," ); // {"abc", "defgh", "ijk"} " abc ,defgh;ijk" .split ( " ,|;" ); // {"abc", "defgh", "ijk"}
{ Ejemplo en Pascal } var lStrings : TStringList ; lStr : cadena ; begin lStrings := TStringList . Create ; lStrings . Delimiter := ',' ; lStrings . DelimitedText := 'abc,defgh,ijk' ; lStr := lStrings . Strings [ 0 ] ; // 'abc' lStr := lStrings . Strings [ 1 ] ; // 'defgh' lStr := lStrings . Strings [ 2 ] ; // 'ijk' end ;
# Ejemplos en Perl 5 split ( /spam/ , 'Huevos de spam, spam, spam y jamón' ); # ('Huevos de spam ', ' ', ' y jamón') split ( /X/ , 'Huevos de spam, spam, spam y jamón' ); # ('Huevos de spam, spam, spam y jamón')
# Ejemplos en Raku 'Huevos de spam, spam, spam y jamón' . split ( /spam/ ); # (Huevos de spam y jamón) split ( /X/ , 'Huevos de spam, spam, spam y jamón' ); # (Huevos de spam, spam, spam y jamón)
ver #Formato
ver #recortar
ver #Comparar (resultado entero)
// Ejemplos en C# "abc" . Substring ( 1 , 1 ): // devuelve "b" "abc" . Substring ( 1 , 2 ); // devuelve "bc" "abc" . Substring ( 1 , 6 ); // error
;; Ejemplos en Common Lisp ( subseq "abc" 1 2 ) ; devuelve "b" ( subseq "abc" 2 ) ; devuelve "c"
% Ejemplos en Erlang cadena : substr ( "abc" , 2 , 1 ). % devuelve "b" cadena : substr ( "abc" , 2 ). % devuelve "bc"
# Ejemplos en Perl 5 substr ( "abc" , 1 , 1 ); # devuelve "b" substr ( "abc" , 1 ); # devuelve "bc"
# Ejemplos en Raku "abc" . substr ( 1 , 1 ); # devuelve "b" "abc" . substr ( 1 ); # devuelve "bc"
# Ejemplos en Python "abc" [ 1 : 2 ] # devuelve "b" "abc" [ 1 : 3 ] # devuelve "bc"
/* Ejemplos en Rexx */ substr ( "abc" , 2 , 1 ) /* devuelve "b" */ substr ( "abc" , 2 ) /* devuelve "bc" */ substr ( "abc" , 2 , 6 ) /* devuelve "bc " */ substr ( "abc" , 2 , 6 , "*" ) /* devuelve "bc****" */
// Ejemplo en C# "¿Wiki significa rápido?" . ToUpper (); // "¿WIKI SIGNIFICA RÁPIDO?"
# Ejemplo en Perl 5 uc ( "¿Wiki significa rápido?" ); # "¿WIKI SIGNIFICA RÁPIDO?"
# Ejemplo en Raku uc ( "¿Wiki significa rápido?" ); # "¿WIKI SIGNIFICA RÁPIDO?" "¿Wiki significa rápido?" . uc ; # "¿WIKI SIGNIFICA RÁPIDO?"
/* Ejemplo en Rexx */ translate ( "¿Wiki significa rápido?" ) /* "¿WIKI SIGNIFICA RÁPIDO?" */ /* Ejemplo n.° 2 */
A = 'Este es un ejemplo'. A
MAYÚSCULA /* "ESTE ES UN EJEMPLO." */ /* Ejemplo n.° 3 */
A = 'upper usando la función de traducción'.
Traducir UPPER VAR A Z /* Z="UPPER USANDO LA FUNCIÓN DE TRADUCCIÓN". */
; Ejemplo en Scheme ( use-modules ( srfi srfi-13 )) ( string-upcase "¿Wiki significa rápido?" ) ; "¿WIKI SIGNIFICA RÁPIDO?"
' Ejemplo en Visual Basic UCase ( "¿Wiki significa rápido?" ) ' "¿WIKI SIGNIFICA RÁPIDO?"
trim
o strip
se utiliza para eliminar espacios en blanco del principio, del final o de ambos, de una cadena.
Otros idiomas
En los idiomas que no tienen una función de recorte incorporada, suele ser sencillo crear una función personalizada que realice la misma tarea.
APL puede utilizar expresiones regulares directamente:
Recortar ← '^ +| +$' ⎕R ''
Como alternativa, un enfoque funcional que combina máscaras booleanas que filtran los espacios iniciales y finales:
Recortar ← { ⍵ /⍨ ( ∨ \ ∧ ∘ ⌽∨ \∘ ⌽ ) ' ' ≠ ⍵ }
O invertir y eliminar los espacios iniciales, dos veces:
Recortar ← { ( ∨ \ ' ' ≠ ⍵ ) / ⍵ } ∘ ⌽ ⍣ 2
En AWK , se pueden usar expresiones regulares para recortar:
ltrim ( v ) = gsub ( /^[ \t]+/ , "" , v ) rtrim ( v ) = gsub ( /[ \t]+$/ , "" , v ) trim ( v ) = ltrim ( v ); recortar ( v )
o:
función ltrim ( s ) { sub ( /^[\t]+/ , "" , s ); devuelve s } función rtrim ( s ) { sub ( /[\t]+$/ , "" , s ); devuelve s } función trim ( s ) { devuelve rtrim ( ltrim ( s )); }
No existe una función de recorte estándar en C o C++. La mayoría de las bibliotecas de cadenas disponibles [55] para C contienen código que implementa el recorte o funciones que facilitan significativamente una implementación eficiente. La función también se ha denominado EatWhitespace en algunas bibliotecas de C no estándar.
En C, los programadores a menudo combinan ltrim y rtrim para implementar trim:
#include <cadena.h> #include <ctype.h> void rtrim ( char * str ) { char * s ; s = str + strlen ( str ); mientras ( --s >= str ) { si ( ! isspace ( * s ) ) romper ; * s = 0 ; } } void ltrim ( char * str ) { tamaño_t n ; n = 0 ; mientras ( str [ n ] != '\0' && isspace (( unsigned char ) str [ n ])) { n ++ ; } memmove ( str , str + n , strlen ( str ) - n + 1 ); } void trim ( char * str ) { rtrim ( str ); ltrim ( str ); }
La biblioteca C++ de código abierto Boost tiene varias variantes de ajuste, incluida una estándar: [56]
#include <boost/algoritmo/cadena/trim.hpp> recortado = boost :: algoritmo :: trim_copy ( "cadena" );
Con la función boost nombrada simplemente, trim
la secuencia de entrada se modifica en el lugar y no devuelve ningún resultado.
Otra biblioteca C++ de código abierto , Qt , tiene varias variantes de ajuste, incluida una estándar: [57]
#include <QString> recortado = s . recortado ();
El núcleo Linux también incluye una función strip, strstrip()
desde la versión 2.6.18-rc1, que recorta la cadena "en su lugar". Desde la versión 2.6.33-rc1, el núcleo utiliza strim()
en lugar de strstrip()
para evitar falsas advertencias. [58]
Un algoritmo de recorte en Haskell :
importar Data.Char ( isSpace ) trim :: String - > String trim = f.f donde f = reverse.dropWhile isSpace
Puede interpretarse de la siguiente manera: f elimina el espacio en blanco anterior e invierte la cadena. Luego, f se aplica nuevamente a su propia salida. Tenga en cuenta que la firma de tipo (la segunda línea) es opcional.
El algoritmo de recorte en J es una descripción funcional :
recortar =. #~ [: ( +./\ *. +./\. ) ' ' &~:
Es decir: filtrar ( #~
) para caracteres que no sean espacios ( ' '&~:
) entre espacios iniciales ( +./\
) y ( *.
) finales ( +./\.
).
Hay una función de recorte incorporada en JavaScript 1.8.1 (Firefox 3.5 y posteriores) y en el estándar ECMAScript 5. En versiones anteriores, se puede agregar al prototipo del objeto String de la siguiente manera:
Cadena . prototipo . trim = función () { devolver esto . reemplazar ( /^\s+/g , "" ). reemplazar ( /\s+$/g , "" ); };
Perl 5 no tiene una función de recorte incorporada. Sin embargo, la funcionalidad se logra comúnmente mediante expresiones regulares .
Ejemplo:
$string =~ s/^\s+//; # remove leading whitespace$string =~ s/\s+$//; # remove trailing whitespace
or:
$string =~ s/^\s+|\s+$//g ; # remove both leading and trailing whitespace
These examples modify the value of the original variable $string
.
Also available for Perl is StripLTSpace in String::Strip
from CPAN.
There are, however, two functions that are commonly used to strip whitespace from the end of strings, chomp
and chop
:
chop
removes the last character from a string and returns it.chomp
removes the trailing newline character(s) from a string if present. (What constitutes a newline is $INPUT_RECORD_SEPARATOR dependent).In Raku, the upcoming sister language of Perl, strings have a trim
method.
Example:
$string = $string.trim; # remove leading and trailing whitespace$string .= trim; # same thing
The Tcl string
command has three relevant subcommands: trim
, trimright
and trimleft
. For each of those commands, an additional argument may be specified: a string that represents a set of characters to remove—the default is whitespace (space, tab, newline, carriage return).
Example of trimming vowels:
set string onomatopoeiaset trimmed [string trim $string aeiou] ;# result is nomatopset r_trimmed [string trimright $string aeiou] ;# result is onomatopset l_trimmed [string trimleft $string aeiou] ;# result is nomatopoeia
XSLT includes the function normalize-space(string)
which strips leading and trailing whitespace, in addition to replacing any whitespace sequence (including line breaks) with a single space.
Example:
<xsl:variable name='trimmed'> <xsl:value-of select='normalize-space(string)'/></xsl:variable>
XSLT 2.0 includes regular expressions, providing another mechanism to perform string trimming.
Another XSLT technique for trimming is to utilize the XPath 2.0 substring()
function.
std::weak_ordering
): less
, equal
(same as equivalent
), or greater
..TRUE.
or .FALSE.
. These functions are based on the ASCII collating sequence.Less
, Equal
, or Greater
.==
and !=
and the methods eq
, ne
are implemented by the PartialEq trait, and the operators <
, >
, <=
, >=
and the methods lt
, gt
, le
, ge
are implemented by the PartialOrd trait.string1
, which must have enough space to store the result+
operator is implemented by the Add trait.startpos
is IBM extension.formatstring
must be a fixed literal at compile time for it to have the correct type.format
.&str
(string reference) can be indexed by various types of ranges, including Range (0..n
), RangeFrom (n..
), and RangeTo (..n
) because they all implement the SliceIndex trait with str
being the type being indexed.
The str::get method is the non-panicking way to index. It returns None in the cases in which indexing would panic.transform
function exists in the std::
namespace. You must include the <algorithm>
header file to use it. The tolower
and toupper
functions are in the global namespace, obtained by the <ctype.h>
header file. The std::tolower
and std::toupper
names are overloaded and cannot be passed to std::transform
without a cast to resolve a function overloading ambiguity, e.g. std::transform(string.begin(), string.end(), result.begin(), (int (*)(int))std::tolower);
std::string
only, result is stored in string result
which is at least as long as string
, and may or may not be string
itselfstartpos
can be negative, which indicates to start that number of places before the end of the string.numChars
puede ser negativo, lo que indica que debe terminar ese número de lugares antes del final de la cadena.startpos
puede ser negativo, utilice * - startpos para indicar que se debe iniciar ese número de lugares antes del final de la cadena.numChars
puede ser negativo, utilice * - numChars para indicar que debe terminar ese número de lugares antes del final de la cadena.endpos
puede ser negativo, lo que indica que debe terminar ese número de lugares antes del final de la cadena.std::string
solamente, el resultado se almacena en la cadena resultado que es al menos tan larga como la cadena y puede o no ser la cadena misma&str
.