que tienen una fecha en este formato: "27-JUN-2011" y quiero convertirlo a 20.110.627Convertir en bash
¿Es posible hacerlo en bash?
que tienen una fecha en este formato: "27-JUN-2011" y quiero convertirlo a 20.110.627Convertir en bash
¿Es posible hacerlo en bash?
#since this was yesterday
date -dyesterday +%Y%m%d
#more precise, and more recommended
date -d'27 JUN 2011' +%Y%m%d
#assuming this is similar to yesterdays `date` question from you
#http://stackoverflow.com/q/6497525/638649
date -d'last-monday' +%Y%m%d
#going on @seth's comment you could do this
DATE = "27 jun 2011"; date -d"$DATE" +%Y%m%d
#or a method to read it from stdin
read -p " Get date >> " DATE; printf " AS YYYYMMDD format >> %s" `date
-d"$DATE" +%Y%m%d`
#which then outputs the following:
#Get date >> 27 june 2011
#AS YYYYMMDD format >> 20110627
#if you really want to use awk
echo "27 june 2011" | awk '{print "date -d\""$1FS$2FS$3"\" +%Y%m%d"}' | bash
#note | bash just redirects awk's output to the shell to be executed
#FS is field separator, in this case you can use $0 to print the line
#But this is useful if you have more than one date on a line
nota esto sólo funciona en la fecha de GNU
He leído que:
versión Solaris de fecha, que es incapaz para apoyar
-d
se pueden resolver con reemplazando sunfreeware.com versión de fecha
date -d "25 JUN 2011" +%Y%m%d
salidas
20110625
Un comando sola fecha parece funcionar bien:
date -d "27 JUN 2011" +%F
+1, bienvenido a stackoverflow, pero% F saca 'YYYY-MM-DD' y el OP era después de 'AAAAMMDD' – matchew
Sólo con bash:
convert_date() {
local months=(JAN FEB MAR APR MAY JUN JUL AUG SEP OCT NOV DEC)
local i
for ((i=0; i<11; i++)); do
[[ $2 = ${months[$i]} ]] && break
done
printf "%4d%02d%02d\n" $3 $((i+1)) $1
}
Y invocarlo como esto
d=$(convert_date 27 JUN 2011)
O si la cadena de fecha "viejo" se almacena en una variable
d_old="27 JUN 2011"
d=$(convert_date $d_old) # not quoted
Tal vez algo ha cambiado desde 2011, pero esto funcionó para mí:
$ date +"%Y%m%d"
20150330
Sin necesidad de que el -d
a obtener el mismo resultado que aparece.
-d establece la fecha que desea formatear. Sin él, la fecha formatea la fecha actual. –
En OSX, estoy usando -f para especificar el formato de entrada, -j para no intentar establecer ninguna fecha, y un especificador de formato de salida. Por ejemplo:
$ date -j -f "%m/%d/%y %H:%M:%S %p" "8/22/15 8:15:00 am" +"%m%d%y"
082215
Su ejemplo:
$ date -j -f "%d %b %Y" "27 JUN 2011" +%Y%m%d
20110627
Si desea una función de bash que funciona tanto en Mac OS X y Linux:
#
# Convert one date format to another
#
# Usage: convert_date_format <input_format> <date> <output_format>
#
# Example: convert_date_format '%b %d %T %Y %Z' 'Dec 10 17:30:05 2017 GMT' '%Y-%m-%d'
convert_date_format() {
local INPUT_FORMAT="$1"
local INPUT_DATE="$2"
local OUTPUT_FORMAT="$3"
local UNAME=$(uname)
if [[ "$UNAME" == "Darwin" ]]; then
# Mac OS X
date -j -f "$INPUT_FORMAT" "$INPUT_DATE" +"$OUTPUT_FORMAT"
elif [[ "$UNAME" == "Linux" ]]; then
# Linux
date -d "$INPUT_DATE" +"$OUTPUT_FORMAT"
else
# Unsupported system
echo "Unsupported system"
fi
}
# Example: 'Dec 10 17:30:05 2017 GMT' => '2017-12-10'
convert_date_format '%b %d %T %Y %Z' 'Dec 10 17:30:05 2017 GMT' '%Y-%m-%d'
Más bien creo OP fue querer analizar el formato de entrada. –
algo así como lo que tengo y luego también respondió con = P nota, respondió a mi pregunta mientras editaba mi respuesta – matchew