![]() |
Extraer el primer caracter de un string
Hola a todos
Estoy desarrollando una aplicación en Delphi 7 y me gustaria que alguien me dijese que comandos puedo utilizar para extraer únicamente la primera letra de un string cualquiera. Por ejemplo, si en el string esta almacenada la palabra "hola" me gustaría poder extraer solamente la letra "h" para compararla posteriormente con otra variable. Si alguien me puede mandar algún ejemplo le estaría muy agradecido. |
Hay varias formas de hacerlo:
Código:
var |
Yo siempre lo hago así.
|
Cita:
|
Ay, sí. :p Me refería a que para extraer los caracteres de una cadena de texto siempre lo trato como un array, que al fin al cabo, una cadena de texto es un array de caracteres
|
¡Hola a todos!
En algunos casos, cuando es seguro que la cadena tenga por lo menos un carácter, utilizo la expresión Cadena [1], pero si existe la posibilidad de que esté vacía, empleo la expresión CaracCade (Cadena), función de Interfaz GH que devuelve #0 en caso de que la cadena esté vacía. Saludos. Al González :). |
Cita:
// Saludos |
Creo que todos aqui han olvidado la posibilidad de manejar lenguajes con caracteres multibyte...
Lo mas probable es que no haga falta, ya que hay una alta probabilidad que se trate de un programa en español...... pero abarcando todas las posibilidades, yo creo que la mejor opción es Copy... Hasta luego. ;) |
Todo tiene un por qué
¡Hola a todos!
Cita:
Entiendo que la función Copy resuelve por si sóla muchas situaciones donde necesitamos una subcadena de uno o varios caracteres. La utilizo en muchos casos. Pero, por ejemplo, resulta más práctico: Código:
Case CaracCade (Cadena) Of Código:
C := Copy (Cadena, 1, 1); Código:
Result := 0; ¡Un abrazo! Al González :). |
Disculpa Al, pero descontando el hecho de que tu segundo bloque de código no compilará, a mi me parece bastante claro este:
que ocupa el mismo número de líneas y no hace referencia a una función que se une a las decenas de funciones incluidas con Delphi que de por sí debe uno mas o menos tener presente. Esto es importante sobre todo cuando debemos leer el código meses después de haberlo escrito. Entendámonos; yo concuerdo en el hecho de que resulta muy útil tener ciertas rutinas que nos eviten trabajar de más pero no llevándolo a sus últimas consecuencias en donde se requiere que el programador disponga de una memoria prodigiosa. // Saludos |
Sabía que lo notarías, jeje. Bueno, supongo que sabías que sabía que lo notarías ;).
Con respecto a recordar el código meses después, es más fácil hacerlo si éste se encuentra simplificado en programación atómica. ¡Saludos! Al González :). |
Cita:
;) // Saludos pd: Estarás de acuerdo que en tu (ahora) tercer bloque el uso de Copy sale sobrando ¿no? |
Para aclarar un poco más lo anterior, me será más fácil recordar qué significa este bloque de código:
Código:
Case CaracCade (S) Of Código:
Result := 0; Un abrazo. Al González :). |
Cita:
¡Hasta pronto! Al González :). |
Cita:
Por otra parte una cadena de caracteres consta, en general, de varios caracteres de manera que CaracCade no da una referencia explícita a qué carcater se está extrayendo. En todo caso PrimerCaracter me parecería más adecuado. // Saludos |
¡Hola de nuevo!
Cita:
Cita:
Seguimos en contacto. Al González :). |
Cita:
// Saludos |
Hola,
Cita:
Saludos. |
Lo digo de memoria, pero la excepción que debiera producirse es un EAccesViolation, pues se trata de acceder a una posición de memoria inválida.
hasta luego. ;) |
En efecto es un EAccessViolation. No sé por qué, pero capturar estas excepciones siempre me pone nervioso :cool:
// Saludos |
Cita:
Cita:
PD: ¿Se dieron cuenta las vueltas que estamos dando para algo tan simple? :D |
Cita:
Saludos. |
También podríamos crear una función de carcater general:
con lo que el código se reduciría a una sóla línea:
:D // Saludos |
Parece que hay una nueva función para agregar a alguna biblioteca... :D
|
Por cierto... los que han trabajado con Oracle han de conocer la excepcional funcion decode...
A mi me ha gustado tanto, que no he podido resistirme a la tentación, y tengo mi propio Decode en delphi... :D :D Al final de cuentas, es mas o menos lo que hizo román... pero de caracter mas general. :eek: :eek: Por supuesto, pertenece a la unidad jachUtils de la biblioteca jach... :D Hasta luego. ;) |
Cita:
:D // Saludos |
Hola,
Cita:
No estoy diciendo que el utilizar funciones externas, como la que has puesto, o a la que se refiere Al, sean una solución peor, sino que, para estos casos, el mecanismo de gestión de excepciones (para Delphi y otros lenguajes que lo implantan) ha demostrado su validez, sencillez y eficacia frente a métodos "tradicionalmente" defensivos (verificar antes que no se dan determinadas circunstancias). Saludos. |
Cita:
... estoy completamente de acuerdo contigo. ¿No lo notas? :p // Saludos |
Cita:
Saludos. |
Cita:
En fin, que esto empezó en el sexto mensaje :p // Saludos |
Cita:
:rolleyes: bueno... las EAccessViolation me ponen algo nervioso... pero es que también soy humano.. :D hasta luego. ;) |
Cita:
:D // Saludos |
Cita:
|
¡Hola a todos!
Cita:
La primera, no se simplificaría nada ya que la expresión A * B es más corta, sencilla, legible y fácil de analizar que la expresión ProduName (A, B). La segunda es que lo recordado no es cómo se hace una operación, sino qué hace una expresión o grupo de expresiones, por lo que la preguna no es ¿cómo se múltiplican dos números?, sino ¿qué hace la expresión ProduNume (A, B)?. Es más fácil respondernos qué hace la expresión A * B o qué hace la expresión Case CaracCade (S) Of, que las alternativas mencionadas. Cabe señalar, que no me refiero al qué hace internamente, sino qué significado operativo tiene en el contexto de código actual. Como habrás notado, CaracCade encapsula la validación If y la referencia al primer carácter de la cadena en una sóla expresión, y ese es el quid de este caso: utilizar una simple y única expresión en lugar de dos o más. Un abrazo. Al González :). |
Mencioné lo de las tablas de multiplicar porque son cosas que aunque en su momento nos hayan costado mucho trabajo, ahora son totalmente naturales y no nos detenemos a pensar gran cosa en ellas, simplemente efectuamos mentalmente la operación de forma automática. Así mismo sucede aquí, como en muchas (si no es que todas) áreas de la actividad humana. Hay cosas que pasan a ser tan naturales que difícilmente tenemos que detenernos a pensar en ellas, y una de éstas es saber que no se puede acceder a un elemento inexistente de un arreglo. Entiendo que para alguien que recién se esté iniciando en el mundo de la programación, puntos como éste no sean triviales, pero llega un momento en que así son, tan naturales como las tablas de multiplicar y requiere más esfuerzo mental extraer de la memoria el objetivo y uso de una función de entre los cientos de funciones que hemos usado aquí o allá en ocasiones anteriores. En el caso que planteas, además de tener que recordar el objetivo de una función, debe uno recordar el uso de sus parámetros. Insisto, un nombre como CaracCade no evoca la extracción del primer caracter de una cadena por lo que debe uno recordar que tiene un parámetro por defecto y que éste se refiere al primer caracater y no, por ejemplo, al último. Cierto, al igual que con muchas funciones incluidas con Delphi, podemos oprimir F1 o consultar la documentación para recordar el funcionamiento exacto, pero, vuelvo al punto inicial, todo esto fue ya más complicado que simplemente leer el código, no encapsulado en una función, que inmediatamente comprenderemos sin necesidad de preguntarnos nada.
No dudo que en tu biblioteca haya muchísimas funciones muy útiles, pero creo que es un exceso querer reusar absolutamente todo el código posible, incluido el más elemental. // Saludos |
La franja horaria es GMT +2. Ahora son las 02:17:45. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi