Saltar para o conteúdo principal
Versão: Próximo

Substring

Substring ( fonte ; aPartirDe {; numCars} ) -> Resultado

ParâmetroTipoDescrição
fonteString🡒Cadeia da qual se tira a substring
aPartirDeInteiro longo🡒Posição do primeiro caractere
numCarsInteiro longo🡒Número de caracteres a pegar
ResultadoString🡐Substring de fonte

Descrição

O comando Substring devolve a parte de fonte definida por aPartirDe e numCars.

O parâmetro aPartirDe indica o primeiro caractere da cadeia a devolver, e numCars define o número de caracteres a devolver.

Se aPartirDe mais numCars é maior que o número de caracteres na cadeia ou se numCars não estiver especificado, Substring devolve todos os caracteres da cadeia a partir do caractere especificado por aPartirDe. Se aPartirDe for superior ao número de caracteres na cadeia, Substring devolve uma cadeia vazia ("").

Atenção: quando se utiliza este comando em um contexto multi-estilo, deve converter os eventuais caracteres de fim de linha Windows ('\r\n') em caracteres de fim de linha simples ('\r') para que o processamento seja válido. Isto se deve ao mecanismo que normaliza os finais de linha 4D para ter certeza a compatibilidade multi-plataforma para os textos. Para obter mais informação, consulte Normalização automática de fins de linhas.

Exemplo 1

Este exemplo ilustra a utilização de Substring. Os resultados são atribuídos à variável vsResult.

 vsResult:=Substring("08/04/62";4;2) // vsResult toma o valor "04"
 vsResult:=Substring("Emergencia";1;6) // vsResult toma o valor "Emerge"
 vsResult:=Substring(var;2) // vsResult toma o valor de todos os caracteres exceto o primeiro

Exemplo 2

O seguinte método de projeto adiciona os parágrafos que são encontrados no texto (passado como primeiro parâmetro) a uma array de tipo texto ou alfa (cujo ponteiro é passado como segundo parâmetro):

  // EXTRACT PARAGRAPHS
  // EXTRACT PARAGRAPHS ( texto ; Ponteiro )
  // EXTRACT PARAGRAPHS ( Texto a analisar ; -> Array de parágrafos )
 
 var $1 : Text
 var $2 : Pointer
 
 $vlElem:=Size of array($2->)
 Repeat
    $vlElem:=$vlElem+1
    INSERT IN ARRAY($2->;$vlElem)
    $vlPos:=Position(Char(Carriage return);$1)
    If($vlPos>0)
       $2->{$vlElem}:=Substring($1;1;$vlPos-1)
       $1:=Substring($1;$vlPos+1)
    Else
       $2->{$vlElem}:=$1
    End if
 Until($1="")

Ver também

Position