Строка даты и времени имеет следующий формат: 12/12/2012 07:21:22. Как я могу преобразовать это в метку времени UNIX или эпоху?
Конвертировать строку даты и времени в эпоху Bash
Ответ 1
То, что вы ищете, это date --date='06/12/2012 07:21:22' +"%s"
. Имейте в виду, что предполагается, что вы используете GNU coreutils, поскольку строки формата --date
и %s
являются расширениями GNU. POSIX не указывает ни один из них, поэтому нет никакого переносимого способа сделать такое преобразование даже в POSIX-совместимых системах.
Обратитесь к соответствующей странице руководства для других версий date
.
Примечание: опция bash --date
и -d
ожидает дату в формате US или ISO8601, т.е. mm/dd/yyyy
или yyyy-mm-dd
, а не в Великобритании, ЕС или в любом другом формате.
Ответ 2
Для Linux Запустите эту команду
date -d '06/12/2012 07:21:22' +"%s"
Для Mac OSX выполните эту команду
date -j -u -f "%a %b %d %T %Z %Y" "Tue Sep 28 19:35:15 EDT 2010" "+%s"
Ответ 3
Многие из этих ответов чрезмерно сложны, а также отсутствуют способы использования переменных. Вот как вы могли бы сделать это проще в стандартной системе Linux (как уже упоминалось ранее, для пользователей Mac должна быть настроена команда date):
Пример сценария:
#!/bin/bash
orig="Apr 28 07:50:01"
epoch=$(date -d "${orig}" +"%s")
epoch_to_date=$(date -d @$epoch +%Y%m%d_%H%M%S)
echo "RESULTS:"
echo "original = $orig"
echo "epoch conv = $epoch"
echo "epoch to human readable time stamp = $epoch_to_date"
Результаты:
RESULTS:
original = Apr 28 07:50:01
epoch conv = 1524916201
epoch to human readable time stamp = 20180428_075001
Или как функция:
# -- Converts from human to epoch or epoch to human, specifically "Apr 28 07:50:01" human.
# typeset now=$(date +"%s")
# typeset now_human_date=$(convert_cron_time "human" "$now")
function convert_cron_time() {
case "${1,,}" in
epoch)
# human to epoch (eg. "Apr 28 07:50:01" to 1524916201)
echo $(date -d "${2}" +"%s")
;;
human)
# epoch to human (eg. 1524916201 to "Apr 28 07:50:01")
echo $(date -d "@${2}" +"%b %d %H:%M:%S")
;;
esac
}
Ответ 4
get_curr_date () {
# get unix time
DATE=$(date +%s)
echo "DATE_CURR : "$DATE
}
conv_utime_hread () {
# convert unix time to human readable format
DATE_HREAD=$(date -d @$DATE +%Y%m%d_%H%M%S)
echo "DATE_HREAD : "$DATE_HREAD
}
Ответ 5
Эффективное решение с использованием date
в качестве фонового выделенного процесса
Чтобы сделать такой перевод намного быстрее...
Введение
В этом посте вы найдете
- быстрое демо, после этого,
- некоторые пояснения,
- Функция, используемая для многих инструментов Un * x (
bc
,rot13
,sed
...).
Быстрая демонстрация
fifo=$HOME/.fifoDate-$$
mkfifo $fifo
exec 5> >(exec stdbuf -o0 date -f - +%s >$fifo 2>&1)
echo now 1>&5
exec 6< $fifo
rm $fifo
read -t 1 -u 6 now
echo $now
Это должно выводить текущий UNIXTIME. Оттуда вы можете сравнить
time for i in {1..5000};do echo >&5 "now" ; read -t 1 -u6 ans;done
real 0m0.298s
user 0m0.132s
sys 0m0.096s
и:
time for i in {1..5000};do ans=$(date +%s -d "now");done
real 0m6.826s
user 0m0.256s
sys 0m1.364s
От более 6 секунд до менее половины секунды !!(на моем хосте).
Вы можете проверить echo $ans
, заменить "now"
на "2019-25-12 20:10:00"
и так далее...
При желании вы можете, как только закончится требование подпроцесса даты:
exec 5>&- ; exec 6<&-
Исходное сообщение (подробное объяснение)
Вместо запуска 1 разветвления по дате для преобразования, запустите date
всего 1 раз и выполните все преобразования с одним и тем же процессом (это может стать намного быстрее) !:
date -f - +%s <<eof
Apr 17 2014
May 21 2012
Mar 8 00:07
Feb 11 00:09
eof
1397685600
1337551200
1520464020
1518304140
Пример:
start1=$(LANG=C ps ho lstart 1)
start2=$(LANG=C ps ho lstart $$)
dirchg=$(LANG=C date -r .)
read -p "A date: " userdate
{ read start1 ; read start2 ; read dirchg ; read userdate ;} < <(
date -f - +%s <<<"$start1"$'\n'"$start2"$'\n'"$dirchg"$'\n'"$userdate" )
Тогда посмотрим:
declare -p start1 start2 dirchg userdate
(may answer something like:
declare -- start1="1518549549" declare -- start2="1520183716" declare -- dirchg="1520601919" declare -- userdate="1397685600"
Это было сделано в одном исполнении!
Использование долго работающего подпроцесса
Нам просто нужна одна пятерка:
mkfifo /tmp/myDateFifo
exec 7> >(exec stdbuf -o0 /bin/date -f - +%s >/tmp/myDateFifo)
exec 8</tmp/myDateFifo
rm /tmp/myDateFifo
(Примечание: поскольку процесс запущен и все дескрипторы открыты, мы можем безопасно удалить запись файловой системы fifo.)
Тогда сейчас:
LANG=C ps ho lstart 1 $$ >&7
read -u 8 start1
read -u 8 start2
LANG=C date -r . >&7
read -u 8 dirchg
read -p "Some date: " userdate
echo >&7 $userdate
read -u 8 userdate
Мы могли бы создать небольшую функцию:
mydate() {
local var=$1;
shift;
echo >&7 [email protected]
read -u 8 $var
}
mydate start1 $(LANG=C ps ho lstart 1)
echo $start1
Или используйте мою функцию newConnector
С функциями для подключения MySQL/MariaDB
, PostgreSQL
и SQLite
...
Вы можете найти их в другой версии на GitHub или на моем сайте: загрузить или показать.
wget https://raw.githubusercontent.com/F-Hauri/Connector-bash/master/shell_connector.bash
. shell_connector.bash
newConnector /bin/date '-f - +%s' @0 0
myDate "2018-1-1 12:00" test
echo $test
1514804400
Примечание: На GitHub функции и тест - это отдельные файлы. На моем сайте тест запускается просто, если этот скрипт не поставлен.
# Exit here if script is sourced
[ "$0" = "$BASH_SOURCE" ] || { true;return 0;}