date(选项)(参数)
-d<字符串>:显示字符串所指的日期与时间。字符串前后必须加上双引号;
-s<字符串>:根据字符串来设置日期与时间。字符串前后必须加上双引号;
-u:显示GMT;
--help:在线帮助;
--version:显示版本信息。
%H 小时,24小时制(00~23)
%I 小时,12小时制(01~12)
%k 小时,24小时制(0~23)
%l 小时,12小时制(1~12)
%M 分(00~59)
%p 显示出上午或下午
%r 时间,12小时制
%s 从1970年1月1日0点到目前经历的秒数
%S 秒(00~59)
%T 时间(24小时制)(hh:mm:ss)
%X 显示时间的格式(%H时%M分%S秒)
%Z 按字母表排序的时区缩写
%a 星期名缩写
%A 星期名全称
%b 月名缩写
%B 月名全称
%c 日期和时间
%d 按月计的日期(01~31)
%D 日期(mm/dd/yy)
%h 和%b选项相同
%j 一年的第几天(001~366)
%m 月份(01~12)
%w 一个星期的第几天(0代表星期天)
%W 一年的第几个星期(00~53,星期一为第一天)
%x 显示日期的格式(mm/dd/yy)
%y 年份的最后两个数字(1999则是99)
%Y 年份(比如1970、1996等)
%C 世纪,通常为省略当前年份的后两位数字
%U 一年中的第几周,以周日为每星期第一天
%e 按月计的日期,添加空格,等于%_d
#格式化当前日期输出:
[root@CncLucZK ~]# date +"%Y/%m/%d"
2022/10/27
#输出7天前日期:
[root@CncLucZK ~]# date -d "7 day ago" +"%Y/%m/%d"
2022/10/20
#2秒后输出:
[root@CncLucZK ~]# date -d "7 second" +"%Y/%m/%d %H:%M:%S"
2022/10/27 14:05:22
#普通字符转时间格式:
[root@CncLucZK ~]# date -d "20221022" +"%Y/%m/%d %H:%M:%S"
2022/10/22 00:00:00
#格式化1234567890秒
[root@CncLucZK ~]# date -d "19700101 987654321 seconds" +"%Y-%m-%d %H:%m:%S"
2001-04-19 04:04:21
#apache格式转换:
[root@CncLucZK ~]# date -d "Oct 27, 2022 12:00:37 AM" +"%Y-%m-%d %H:%M:%S"
2022-10-27 00:00:37
#格式转换后时间游走:
[root@CncLucZK ~]# date -d "Oct 27, 2022 12:00:37 AM 2 year" +"%Y-%m-%d %H:%M:%S"
2024-10-27 00:00:37
date +%Y%m%d //显示当天年月日
date -d "+2 day" +%Y%m%d //显示后两天的日期
date -d "-2 day" +%Y%m%d //显示前两天的日期
date -d "-1 month" +%Y%m%d //显示上一月的日期
date -d "+1 month" +%Y%m%d //显示下一月的日期
date -d "-1 year" +%Y%m%d //显示前一年的日期
date -d "+1 year" +%Y%m%d //显示下一年的日期
date -s //设置当前时间,只有root权限才能设置,其他只能查看
date -s 20221027 //设置成20221027,这样会把具体时间设置成空00:00:00
date -s 01:01:01 //设置具体时间,不会对日期做更改
date -s "01:01:01 2022-10-27" //这样可以设置全部时间
date -s "01:01:01 20221027" //这样可以设置全部时间
date -s "2022-10-27 01:01:01" //这样可以设置全部时间
date -s "2221027 01:01:01" //这样可以设置全部时间
#!/bin/bash
start=$(date +%s)
echo "hello linux!" >> /test/tmp.txt
end=$(date +%s)
difference=$(( end - start ))
echo $difference seconds.
tr(选项)(参数)
选项
参数:
字符集1:指定要转换或删除的原字符集。当执行转换操作时,必须使用参数“字符集2”指定转换的目标字符集。但执行删除操作时,不需要参数“字符集2”;
字符集2:指定要转换成的目标字符集。
#将输入字符由大写转换为小写:
echo "HELLO WORLD" | tr 'A-Z' 'a-z'
hello world
#'A-Z' 和 'a-z'都是集合,集合是可以自己制定的,例如:'ABD-}'、'bB.,'、'a-de-h'、'a-c0-9'都属于集合,集合里可以使用'\n'、'\t',可以可以使用其他ASCII字符。
#使用tr删除字符:
echo "hello 123 world 456" | tr -d '0-9'
hello world
#将制表符转换为空格:
cat text | tr '\t' ' '
#字符集补集,从输入文本中将不在补集中的所有字符删除:
echo aa.,a 1 b#$bb 2 c*/cc 3 ddd 4 | tr -d -c '0-9 \n'
1 2 3 4
#此例中,补集中包含了数字0~9、空格和换行符\n,所以没有被删除,其他字符全部被删除了。
#用tr压缩字符,可以压缩输入中重复的字符:
echo "thissss is a text linnnnnnne." | tr -s ' sn'
this is a text line.
#巧妙使用tr做数字相加操作:
echo 1 2 3 4 5 6 7 8 9 | xargs -n1 | echo $[ $(tr '\n' '+') 0 ]
#删除Windows文件“造成”的'^M'字符:
cat file | tr -s "\r" "\n" > new_file
或
cat file | tr -d "\r" > new_file
[:alnum:]:字母和数字
[:alpha:]:字母
[:cntrl:]:控制(非打印)字符
[:digit:]:数字
[:graph:]:图形字符
[:lower:]:小写字母
[:print:]:可打印字符
[:punct:]:标点符号
[:space:]:空白字符
[:upper:]:大写字母
[:xdigit:]:十六进制字符
tr '[:lower:]' '[:upper:]'