Debian 9 与 Debian 10 的日期输出不同,相同的语言环境,相同的时区

Debian 9 与 Debian 10 的日期输出不同,相同的语言环境,相同的时区

您能否告知造成这种差异的原因是什么?如何使用date命令(不带其他参数)将 Debian 10 的输出更改为显示 24 小时格式。

Debian 9

date输出:

Wed Oct 30 13:10:21 CET 2019

timedatectl

      Local time: Wed 2019-10-30 13:11:46 CET
  Universal time: Wed 2019-10-30 12:11:46 UTC
        RTC time: Wed 2019-10-30 12:11:46
       Time zone: Europe/Warsaw (CET, +0100)
 Network time on: yes
NTP synchronized: yes
 RTC in local TZ: no

locale输出:

LANG=en_US.UTF-8
LANGUAGE=
LC_CTYPE="en_US.UTF-8"
LC_NUMERIC="en_US.UTF-8"
LC_TIME="en_US.UTF-8"
LC_COLLATE="en_US.UTF-8"
LC_MONETARY="en_US.UTF-8"
LC_MESSAGES="en_US.UTF-8"
LC_PAPER="en_US.UTF-8"
LC_NAME="en_US.UTF-8"
LC_ADDRESS="en_US.UTF-8"
LC_TELEPHONE="en_US.UTF-8"
LC_MEASUREMENT="en_US.UTF-8"
LC_IDENTIFICATION="en_US.UTF-8"
LC_ALL=

locale -a输出:

C
C.UTF-8
en_US.utf8
POSIX

Debian 10

date

Wed 30 Oct 2019 01:10:57 PM CET

timedatectl

               Local time: Wed 2019-10-30 13:11:13 CET
           Universal time: Wed 2019-10-30 12:11:13 UTC
                 RTC time: n/a
                Time zone: Europe/Warsaw (CET, +0100)
System clock synchronized: yes
              NTP service: inactive
          RTC in local TZ: no

locale输出:

LANG=en_US.UTF-8
LANGUAGE=
LC_CTYPE="en_US.UTF-8"
LC_NUMERIC="en_US.UTF-8"
LC_TIME=en_US.utf8
LC_COLLATE="en_US.UTF-8"
LC_MONETARY="en_US.UTF-8"
LC_MESSAGES="en_US.UTF-8"
LC_PAPER="en_US.UTF-8"
LC_NAME="en_US.UTF-8"
LC_ADDRESS="en_US.UTF-8"
LC_TELEPHONE="en_US.UTF-8"
LC_MEASUREMENT="en_US.UTF-8"
LC_IDENTIFICATION="en_US.UTF-8"
LC_ALL=

locale -a输出:

aa_DJ
aa_DJ.utf8
aa_ER
aa_ER@saaho
aa_ET
af_ZA
af_ZA.utf8
agr_PE
ak_GH
am_ET
an_ES
an_ES.utf8
anp_IN
ar_AE
ar_AE.utf8
ar_BH
ar_BH.utf8
ar_DZ
ar_DZ.utf8
ar_EG
ar_EG.utf8
ar_IN
ar_IQ
ar_IQ.utf8
ar_JO
ar_JO.utf8
ar_KW
ar_KW.utf8
ar_LB
ar_LB.utf8
ar_LY
ar_LY.utf8
ar_MA
ar_MA.utf8
ar_OM
ar_OM.utf8
ar_QA
ar_QA.utf8
ar_SA
ar_SA.utf8
ar_SD
ar_SD.utf8
ar_SS
ar_SY
ar_SY.utf8
ar_TN
ar_TN.utf8
ar_YE
ar_YE.utf8
as_IN
ast_ES
ast_ES.utf8
ayc_PE
az_AZ
az_IR
be_BY
be_BY@latin
be_BY.utf8
bem_ZM
ber_DZ
ber_MA
bg_BG
bg_BG.utf8
bhb_IN.utf8
bho_IN
bho_NP
bi_VU
bn_BD
bn_IN
bo_CN
bo_IN
br_FR
br_FR@euro
br_FR.utf8
brx_IN
bs_BA
bs_BA.utf8
byn_ER
C
ca_AD
ca_AD.utf8
ca_ES
ca_ES@euro
ca_ES.utf8
ca_ES@valencia
ca_FR
ca_FR.utf8
ca_IT
ca_IT.utf8
ce_RU
chr_US
cmn_TW
crh_UA
csb_PL
cs_CZ
cs_CZ.utf8
C.UTF-8
cv_RU
cy_GB
cy_GB.utf8
da_DK
da_DK.utf8
de_AT
de_AT@euro
de_AT.utf8
de_BE
de_BE@euro
de_BE.utf8
de_CH
de_CH.utf8
de_DE
de_DE@euro
de_DE.utf8
de_IT
de_IT.utf8
de_LI.utf8
de_LU
de_LU@euro
de_LU.utf8
doi_IN
dsb_DE
dv_MV
dz_BT
el_CY
el_CY.utf8
el_GR
el_GR@euro
el_GR.utf8
en_AG
en_AU
en_AU.utf8
en_BW
en_BW.utf8
en_CA
en_CA.utf8
en_DK
en_DK.iso885915
en_DK.utf8
en_GB
en_GB.iso885915
en_GB.utf8
en_HK
en_HK.utf8
en_IE
en_IE@euro
en_IE.utf8
en_IL
en_IN
en_NG
en_NZ
en_NZ.utf8
en_PH
en_PH.utf8
en_SC.utf8
en_SG
en_SG.utf8
en_US
en_US.iso885915
en_US.utf8
en_ZA
en_ZA.utf8
en_ZM
en_ZW
en_ZW.utf8
eo
es_AR
es_AR.utf8
es_BO
es_BO.utf8
es_CL
es_CL.utf8
es_CO
es_CO.utf8
es_CR
es_CR.utf8
es_CU
es_DO
es_DO.utf8
es_EC
es_EC.utf8
es_ES
es_ES@euro
es_ES.utf8
es_GT
es_GT.utf8
es_HN
es_HN.utf8
es_MX
es_MX.utf8
es_NI
es_NI.utf8
es_PA
es_PA.utf8
es_PE
es_PE.utf8
es_PR
es_PR.utf8
es_PY
es_PY.utf8
es_SV
es_SV.utf8
es_US
es_US.utf8
es_UY
es_UY.utf8
es_VE
es_VE.utf8
et_EE
et_EE.iso885915
et_EE.utf8
eu_ES
eu_ES@euro
eu_ES.utf8
eu_FR
eu_FR@euro
eu_FR.utf8
fa_IR
ff_SN
fi_FI
fi_FI@euro
fi_FI.utf8
fil_PH
fo_FO
fo_FO.utf8
fr_BE
fr_BE@euro
fr_BE.utf8
fr_CA
fr_CA.utf8
fr_CH
fr_CH.utf8
fr_FR
fr_FR@euro
fr_FR.utf8
fr_LU
fr_LU@euro
fr_LU.utf8
fur_IT
fy_DE
fy_NL
ga_IE
ga_IE@euro
ga_IE.utf8
gd_GB
gd_GB.utf8
gez_ER
gez_ER@abegede
gez_ET
gez_ET@abegede
gl_ES
gl_ES@euro
gl_ES.utf8
gu_IN
gv_GB
gv_GB.utf8
hak_TW
ha_NG
he_IL
he_IL.utf8
hif_FJ
hi_IN
hne_IN
hr_HR
hr_HR.utf8
hsb_DE
hsb_DE.utf8
ht_HT
hu_HU
hu_HU.utf8
hy_AM
hy_AM.armscii8
ia_FR
id_ID
id_ID.utf8
ig_NG
ik_CA
is_IS
is_IS.utf8
it_CH
it_CH.utf8
it_IT
it_IT@euro
it_IT.utf8
iu_CA
ja_JP.eucjp
ja_JP.utf8
kab_DZ
ka_GE
ka_GE.utf8
kk_KZ
kk_KZ.rk1048
kk_KZ.utf8
kl_GL
kl_GL.utf8
km_KH
kn_IN
kok_IN
ko_KR.euckr
ko_KR.utf8
ks_IN
ks_IN@devanagari
ku_TR
ku_TR.utf8
kw_GB
kw_GB.utf8
ky_KG
lb_LU
lg_UG
lg_UG.utf8
li_BE
lij_IT
li_NL
ln_CD
lo_LA
lt_LT
lt_LT.utf8
lv_LV
lv_LV.utf8
lzh_TW
mag_IN
mai_IN
mai_NP
mfe_MU
mg_MG
mg_MG.utf8
mhr_RU
mi_NZ
mi_NZ.utf8
miq_NI
mjw_IN
mk_MK
mk_MK.utf8
ml_IN
mni_IN
mn_MN
mr_IN
ms_MY
ms_MY.utf8
mt_MT
mt_MT.utf8
my_MM
nan_TW
nan_TW@latin
nb_NO
nb_NO.utf8
nds_DE
nds_NL
ne_NP
nhn_MX
niu_NU
niu_NZ
nl_AW
nl_BE
nl_BE@euro
nl_BE.utf8
nl_NL
nl_NL@euro
nl_NL.utf8
nn_NO
nn_NO.utf8
nr_ZA
nso_ZA
oc_FR
oc_FR.utf8
om_ET
om_KE
om_KE.utf8
or_IN
os_RU
pa_IN
pap_AW
pap_CW
pa_PK
pl_PL
pl_PL.utf8
POSIX
ps_AF
pt_BR
pt_BR.utf8
pt_PT
pt_PT@euro
pt_PT.utf8
quz_PE
raj_IN
ro_RO
ro_RO.utf8
ru_RU
ru_RU.cp1251
ru_RU.koi8r
ru_RU.utf8
ru_UA
ru_UA.utf8
rw_RW
sah_RU
sa_IN
sat_IN
sc_IT
sd_IN
sd_IN@devanagari
se_NO
sgs_LT
shn_MM
shs_CA
sid_ET
si_LK
sk_SK
sk_SK.utf8
sl_SI
sl_SI.utf8
sm_WS
so_DJ
so_DJ.utf8
so_ET
so_KE
so_KE.utf8
so_SO
so_SO.utf8
sq_AL
sq_AL.utf8
sq_MK
sr_ME
sr_RS
sr_RS@latin
ss_ZA
st_ZA
st_ZA.utf8
sv_FI
sv_FI@euro
sv_FI.utf8
sv_SE
sv_SE.iso885915
sv_SE.utf8
sw_KE
sw_TZ
szl_PL
ta_IN
ta_LK
tcy_IN.utf8
te_IN
tg_TJ
tg_TJ.utf8
the_NP
th_TH
th_TH.utf8
ti_ER
ti_ET
tig_ER
tk_TM
tl_PH
tl_PH.utf8
tn_ZA
to_TO
tpi_PG
tr_CY
tr_CY.utf8
tr_TR
tr_TR.utf8
ts_ZA
tt_RU
tt_RU@iqtelif
ug_CN
uk_UA
uk_UA.utf8
unm_US
ur_IN
ur_PK
uz_UZ
uz_UZ@cyrillic
uz_UZ.utf8
ve_ZA
vi_VN
wa_BE
wa_BE@euro
wa_BE.utf8
wae_CH
wal_ET
wo_SN
xh_ZA
xh_ZA.utf8
yi_US
yi_US.utf8
yo_NG
yue_HK
yuw_PG
zh_CN
zh_CN.gb18030
zh_CN.gbk
zh_CN.utf8
zh_HK
zh_HK.utf8
zh_SG
zh_SG.gbk
zh_SG.utf8
zh_TW
zh_TW.euctw
zh_TW.utf8
zu_ZA
zu_ZA.utf8

答案1

您能否告知造成这种差异的原因是什么?

我下载了适用于 Debian 9 和 Debian 10 的软件包 ( locales) 并检查了名为的文件en_US。我还遵循了本指南并设法以自定义名称注入这两个文件,这样我就可以使用同一系统上的任何命令分别设置LC_TIME=en_UScustom9.UTF-8LC_TIME=en_UScustom10.UTF-8使用 Debian 9 或 10 的语言环境(记录:系统是 Debian 9)。

结论:

  1. Debian 10 的文件包含

    % Appropriate date and time representation (%c)
    d_t_fmt "%a %d %b %Y %r %Z"
    

    % Appropriate date and time representation for date(1)
    date_fmt "%a %d %b %Y %r %Z"
    

    但 Debian 9 的文件包含

    % Appropriate date and time representation (%c)
    %       "%a %d %b %Y %r %Z"
    d_t_fmt "<U0025><U0061><U0020><U0025><U0064><U0020><U0025><U0062><U0020><U0025><U0059><U0020><U0025><U0072><U0020><U0025><U005A>"
    

    并且没有 的条目date_fmt

  2. 实际上发生了以下情况:

    $ LC_TIME=en_UScustom10.UTF-8 locale d_t_fmt                                                                               
    %a %d %b %Y %r %Z
    $ LC_TIME=en_UScustom10.UTF-8 locale date_fmt                                                                              
    %a %d %b %Y %r %Z
    $ LC_TIME=en_UScustom9.UTF-8 locale d_t_fmt
    %a %d %b %Y %r %Z
    $ LC_TIME=en_UScustom9.UTF-8 locale date_fmt
    %a %b %e %H:%M:%S %Z %Y
    $
    

    我猜最后一种情况date_fmt会恢复为默认值。比较一下:

    $ LC_TIME=POSIX locale date_fmt
    %a %b %e %H:%M:%S %Z %Y
    $
    
  3. 我理解d_t_fmt描述了%c格式,而date_fmt描述了 的默认格式date。这种情况会发生:

    $ LC_TIME=en_UScustom10.UTF-8 date +%c
    Thu 31 Oct 2019 01:23:01 AM CET
    $ LC_TIME=en_UScustom10.UTF-8 date
    Thu 31 Oct 2019 01:23:01 AM CET
    $ LC_TIME=en_UScustom9.UTF-8 date +%c
    Thu 31 Oct 2019 01:23:02 AM CET
    $ LC_TIME=en_UScustom9.UTF-8 date
    Thu Oct 31 01:23:02 CET 2019
    $
    
  4. 看来您在 Debian 10 中观察到的是正确的行为en_US.UTF-8。在 Debian 9 中date_fmt未定义,这可能是一个错误。我猜date_fmt应该匹配d_t_fmt,文件应该被修补。

    如果已打补丁,它根本帮不了你。它会让dateDebian 9 的行为与 Debian 10 的行为类似。你想要 Debian 9 的行为。


如何使用 date 命令更改 Debian 10 的输出以显示 24 小时格式?(无需附加参数)。

选一个:

  • 创建具有自定义名称的自定义语言环境(从 Debian 9 复制语言环境)并使用它。
    (我不会在这里讨论这个主题。如果需要,请进行研究并提出单独的问题。)
  • 将其放置在您的.profile

    export LC_TIME=POSIX
    

    这样,soledate就会打印您想要的格式。请注意,此解决方案也会影响其他格式(如%c);请决定是否可以接受。

如果我是你,我会将选择的解决方案不仅应用于 Debian 10,还会应用于 Debian 9,以防文件被修补。

答案2

来自GNU coreutils 页面

调用不带格式参数的日期相当于使用取决于 LC_TIME 语言环境类别的默认格式调用它。在默认的 C 语言环境中,此格式为“+%a %b %e %H:%M:%S %Z %Y”,因此输出看起来像“Thu Mar 3 13:47:51 PST 2005”。

那么两个系统的输出locale LC_TIME(特别是倒数第二行)是什么?

请注意,变量 LC_TIME 的值可能不是某个系统上的有效语言环境名称,在这种情况下,看起来使用的是默认的 C 语言环境。

解决方法

对于您的命令提示符,您可以定义一个别名:

alias date='date "+%c"

%c是区域敏感的格式:

alias date='date +%c'

>export LC_TIME=en_US.utf8
>date
Wed 30 Oct 2019 01:33:24 PM CET

>export LC_TIME=en_GB.utf8
>date
Wed 30 Oct 2019 13:35:09 CET

当然,您可以使用自己手工定制的日期格式定义别名。

相关内容