我目前有一个制表符分隔的文本文件,格式如下:
David Webb Box 34 Rural Route 2 Nixa MO 65714 (417)555-1478 555-66-7788 09-13-1970
Martha Kent 1122 North Hwy 5 Smallville KS 66789 (785)555-2322 343-55-8845 04-17-1965
Edward Nygma 443 W. Broadway Gotham City NJ 12458 (212)743-3537 785-48-5524 08-08-1987
我正在尝试格式化日期而September 13, 1970
不是09-13-1970
我一直在尝试做的是cut -f 9 file > tmpfile
然后使用
date -f tmpfile "+%B %d, %Y" > date
但它一直说
date: invalid date ‘09-13-1970’
date: invalid date ‘04-17-1965’
date: invalid date ‘08-08-1987’
我究竟做错了什么?
答案1
日期不接受该输入格式,请尝试将年份放在前面,例如流编辑输入:
cut -f 9 file | sed 's/\(..\)-\(..\)-\(....\)/\3-\1-\2/' > tmpfile
手工测试:
$ date --date '09-13-1970' "+%B %d, %Y"
date: invalid date ‘09-13-1970’
$ date --date '09/13/1970' "+%B %d, %Y"
September 13, 1970
$ date --date '1970/09/13' "+%B %d, %Y"
September 13, 1970
$ date --date '1970-09-13' "+%B %d, %Y"
September 13, 1970
答案2
这是使用 awk 的版本,不需要中间文件。
#!/bin/awk -f
BEGIN {FS="\t"; OFS="\t"}
{
split($9,A,"-");
S1 = sprintf("%d %d %d 0 0 0",A[3],A[1],A[2])
D1 = strftime("%B %d, %Y", mktime(S1))
$9 = D1
print
}