Section: Manual del Programador de Linux (3)
Updated: 11 marzo 1998
Index Return to Main
Contents
strptime - convierte una cadena de caracteres que representa un tiempo a una estructura tm
char *strptime(const char *s, const char *format, struct tm *tm);
strptime() es la función complementaria de strftime() y convierte la cadena de caracteres a la que apunte s a un valor de tiempo, que se guarda en la estructura tm a la que apunte tm, utilizando el formato especificado por format. format es una cadena de caracteres que consiste en descriptores de campos y caracteres de texto, una reminiscencia de scanf(3). Cada descriptor de campo consiste en un carácter de porcentaje % seguido por otro carácter que especifica el reemplazo para el descriptor de campo. Todos los otros caracteres de la cadena format deben tener un carácter concordante en la cadena de entrada. Excepciones son los espacios en blanco de la cadena de formato que pueden concordar con cero o más espacios en blanco de la cadena de entrada.
La función strptime() procesa la cadena de entrada de derecha a izquierda. Cada uno de los tres posibles elementos de entrada (espacio en blanco, literal o formato) se tratan uno detrás de otro. Si no se puede hacer coincidir la entrada con la cadena de formato, la función se detiene. El resto de las cadenas de formato y de entrada no se procesa.
Se admiten los siguientes descriptores de campo:
No se distinguen mayúsculas de minúsculas en la concordancia de elementos como nombres de meses o días de la semana.
La estructura de tiempo descompuesto tm se define en <time.h> como sigue:
struct tm { int tm_sec; /* segundos */ int tm_min; /* minutos */ int tm_hour; /* horas */ int tm_mday; /* día del mes */ int tm_mon; /* mes */ int tm_year; /* año */ int tm_wday; /* día de la semana */ int tm_yday; /* día del año */ int tm_isdst; /* ¿cambio horario? */ };
El valor devuelto por la función es un puntero al primer carácter no procesado en esta llamada a la función. En el caso de que la cadena de entrada contenga más caracteres de los que necesita la cadena de formato, el valor devuelto apunta justo después del último carácter de entrada consumido. En el caso de que se consuma toda la cadena de entrada, el valor devuelto apunta al byte NUL al final de la cadena. Si strptime() no puede hacer coincidir toda la cadena de formato y, por tanto, se ha producido un error, la función devuelve NULL.
(3), time(2), setlocale(3), scanf(3)
La especificación de la función en el estándar XPG es bastante vaga. Omite algunos trozos importantes de información. Sobre todo, no especifica qué ocurre con aquellos elementos de tm que no son directamente inicializados por los diferentes formatos. Diversas implementanciiones en sistemas Unix diferentes pueden variar en esto.
La implementación de la libc de GNU no toca aquellos campos que no son directamente inicializados. Excepciones son los elementos tm_wday y tm_yday que se recalculan si cualquiera de los elementos de año, mes o fecha cambia.
Esta función sólo está disponible en bibliotecas posteriores a la versión 4.6.5. Los ficheros de cabecera de las librerías libc4 y libc5 de Linux definen el prototipo de forma incondicional. Los ficheros cabecera de glibc2 proporcionan un prototipo sólo cuando se define _XOPEN_SOURCE o _GNU_SOURCE.
La función sólo admite aquellas localizaciones especificadas en locale(7)
This document was created by man2html, using
the manual pages.
Time: 06:16:23 GMT, January 22, 2005