Manual del Programador de Linux (3)
11 marzo 1998
 

NOMBRE

strptime - convierte una cadena de caracteres que representa un tiempo a una estructura tm  

SINOPSIS

#include <time.h>

char *strptime(const char *s, const char *format, struct tm *tm);  

DESCRIPCIÓN

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:

%%
lo mismo que %
%a
%A
día de la semana, empleando los nombres de los días de la semana correspondientes a la localización; puede especificarse el nombre abreviado o el completo
%b
%B
%h
mes, empleando los nombres de meses correspondientes a la localización; puede especificarse el nombre abreviado o el completo.
%c
fecha y hora como %x %X
%C
fecha y hora, en la representación local de la fecha y hora en formato largo
%d
%e
día del mes (1--31; se permiten pero no se requieren ceros iniciales)
%D
fecha como %m/%d/%y
%H
%k
hora (0--23; se permiten pero no se requieren ceros iniciales)
%I
%l
hora (0--12; se permiten pero no se requieren ceros iniciales)
%j
día juliano (número del día del año, de 001 a 366)
%m
número del mes (1--12; se permiten pero no se requieren ceros iniciales)
%M
minuto (0-59; se permiten pero no se requieren ceros iniciales)
%p
el equivalente local de AM o de PM
%r
hora como %I:%M:%S %p
%R
hora como %H:%M
%S
segundos (0--61; se permiten pero no se requieren ceros iniciales. El segundo extra es para años bisiestos)
%T
hora como %H:%M:%S
%w
número de día de la semana (0--6) con el Domingo como primer día de la semana
%x
fecha, empleando el formato local para la fecha
%X
hora, empleando el formato local
%y
año dentro de la centuria (0--99; se permiten pero no se requieren ceros iniciales. Desafortunadamente esto presume que estamos atascados en el siglo XX puesto que se suma 1900 automáticamente a este número para el campo tm_year)
%Y
año, incluyendo la centuria (por ejemplo, 1998)

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? */
};
 

VALOR DEVUELTO

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.  

VÉASE TAMBIÉN

strftime

(3), time(2), setlocale(3), scanf(3)  

OBSERVACIONES

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)

Nuevo comentario