0%

Linux shell 获取更改系统时间

date命令可以用来打印显示亦或者更改日期和时间。

看看官方的定义如下:

date - print or set the system date and time

用法如下:

1
2
$ date [OPTION]... [+FORMAT]
$ date [-u | --utc| --universal] [MMDDhhmm[[CC]YY][.ss]]

较常用的OPTION为:

  • -R : 显示时区
  • -u, --utc, --universal:打印或者设置世界协调时
  • -d, --date=STRING:显示STRING的时间

默认输入

date 命令默认情况下为CST时区,

1
2
$ date
Mon Jun 5 15:11:44 CST 2014

显示时区

如果加上 -R参数就可以带上时区,比如我们的东八区

1
2
$ date -R
Mon, 05 Jun 2014 15:15:25 +0800

世界协调时

选项-u, --utc, --universal可以显示世界协调时

1
2
3
4
5
6
7
8
$ date -u
Mon Jun 5 07:15:46 UTC 2014

$ date --utc
Mon Jun 5 07:15:48 UTC 2014

$ date --universal
Mon Jun 5 07:15:55 UTC 2014

格式化日期

可以通过不同的参数来格式化日期,这里需要注意的是:不同的大小写代表的是不同的含义

比较常用的日期和时间如下:

1
2
3
4
5
6
7
8
# 显示年月日时分秒
$ date +%Y-%m-%dT%H:%M:%S
2013-01-17T18:01:08

# 或者 下面一样的效果

$ data +%FT%T
2013-01-17T18:02:12

这里注意到有+这个选项,后面的就是格式字符串,常见常用的有下面几个。

格式化参数 含义
%a 星期的缩写,比如Sun
%A 星期的全称,比如Sunday
%b 月份的缩写,比如Jan
%B 月份的全称,比如January
%c 日期和时间,比如Thu Mar 3 23:05:25 2005
%d 日期,比如02
%D 日期,格式为月/日/年,比如:01/17/13,即为2013年1月17日
%F 日期的全写,格式为年-月-日,比如2013-01-17
%H 小时,从00到23,24小时制
%I 小时,从01到12,12小时制
%j 一年中的第几天,从001到366
%m 月份,比如:01
%M 分钟,比如56
%N 纳秒,范围为:(000000000..999999999)
%p 使用AM或PM
%P 使用am或pm
%q 显示季度(范围1到4)
%r 12进制显示,比如:10:23:51 PM
%R 24进制显示时分,类似于%H:%M
%s 自UTC1970-01-01 00:00:00以来的秒数
%S 秒,比如28
%T 显示时间,格式为:%H:%M:%S
%u 一周的第几天,从1到7
%U 一年的第几周,周日为第一天,范围00到53
%V 与%U类似,使用Monday作为第一天,范围01到53
%w 星期,如果结果显示0,则表示周日
%W 一年的第几周,周一为第一天,范围00到53
%x 本地日期,格式mm/dd/yy
%X 本地时间,格式hh:mm:ss
%Y 以四位数字格式打印年份 ,比如 2014
%y 以二位数字格式打印年份 ,比如14
%z 数字时区,格式为+hhmm
%Z 字母时区,比如EDT、CST

还有一些可选的参数,比如:^,使用方法为date +%^b,此时的输出改为大写,如果date +%b输出为Jan,那么加上^的输出为JAN

转换秒到日期时间

下面的方法为将UTC 1970-01-01 00:00:00经过123456789秒以后的日期时间显示出来。

1
2
$ date --date='@123456789'
Fri Nov 30 05:33:09 CST 1973

–date选项花样多

-d, --date=STRING能描述和使用的STRING很多很复杂,比如可以这么用:

1
2
3
4
5
6
7
8
9
$ date --date="next Week"

$ date --date="next Month"

$ date --date="1 year ago"

$ date --date="4 days"

$ date --date="4 days ago"

还有很多其他的用法,可以参考info date

Linux shell获取系统时间

1
2
3
4
5
6
7
8
9
10
11
12
#!/bin/bash
echo "time now is:"
read hours
if [ $hours -lt 12 ]
then
echo "good morning"
elif [ $hours -ge 12 ] && [ $hours -lt 20 ]
then
echo "good afternoon"
else
echo "good night"
fi

调用系统时后:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#!/bin/bash
echo "time now is:"
echo `date`
#read hours
hours=`date +%H`
echo "Hours : $hours"
if [ $hours -lt 12 ]
then
echo "good morning"
elif [ $hours -ge 12 ] && [ $hours -lt 20 ]
then
echo "good afternoon"
else
echo "good night"
fi

这里注意的地方是 等号两边不要空格

获取系统时间之当前小时的语句是

1
hours=`date +%H`

如果想系统时间按格式显示,则可改为

1
echo `date +"%Y-%m-%d-%H:%M:%S"`

运行结果为:

1
2013-01-17-18:01:08

这里需要注意的是:不同的大小写代表的是不同的含义

1
2
3
4
5
6
7
8
date +%Y 以四位数字格式打印年份 eg: 2018
date +%y 以二位数字格式打印年份 eg: 18
date +%m 月份
date +%d 日期
date +%H 小时
date +%M 分钟
date +%S 秒
date +%w 星期,如果结果显示0,则表示周日

Linux fdisk 命令

Fdisk is the most commonly used command to check the partitions on a disk. The fdisk command can display the partitions and details like file system type. However it does not report the size of each partitions.

1
$ fdisk -l #显示所有的分区表

fedora17升级到18

fedora 18的升级工具不再是pre-upgrade了,而是换成了fedup。

先安装fedup,使用fedup升级的方法:

1
sudo fedup –network 18

IF you can not find the network configure.

May be you should TYPE:

1
system-config-network

to setting IP info.

import is a feature provided by the GCC compiler, which is what Xcode uses when you’re compiling Objective- C, C, and C++ programs. #import guarantees that a header file will be included only once, no matter how many times the #import directive is actually seen for that file.

NOTE

In C, programmers typically use a scheme based on the #ifdef directive to avoid the situation where one file includes a second file, which then, recursively, includes the first.

In Objective- C, programmers use #import to accomplish the same thing.

So import equals to ifndef plus include.

关于断言assert的使用

assert宏的原型定义在<assert.h>中,其作用是如果它的条件返回错误,则终止程序执行,原型定义:

1
2
3
#include <assert.h>

void assert( int expression );

assert的作用是先计算表达式 expression ,如果其值为假(即为0),那么它先向stderr打印一条出错信息,然后通过调用 abort 来终止程序运行。

但是使用assert()的缺点是,频繁的调用会极大的影响程序的性能,增加额外的开销。在调试结束后,可以通过在包含#include <assert.h>的语句之前插入 #define NDEBUG` 来禁用assert调用。

我比较常用的比如断言分母不能是0等等。

程序编译的过程

一个程序的编译,需要完成词法分析、语法分析、中间代码生成、代码优化、目标代码生成。
而编译的过程包括预处理preprocessing、编译compilation、汇编assembly和链接linking。

  1. 词法分析。词法分析指的是对由字符组成的单词进行处理,从左至右逐个字符地对源程序进行扫描,产生一个个单词符号,然后把字符串的源程序改造成单词符号串的中间程序。在编译程序时,这一过程是自动完成的。编译程序会对代码的每个单词进行检查,如果单词发生错误,编译过程就会停止并显示错误,这时需要对程序中的错误进行修改。
  2. 语法分析。语法分析器以单词符号作为输入,分析单词符号串是否形成符合语法规则的语句。例如,需要检查表达式、赋值、循环等结构是否完整和符合使用规则。在语法分析时,会分析出程序中错误的语句,并显示出结果。如果语法发生错误,编译任务是不能完成的。
  3. 中间代码生成。中间代码是源程序的一种内部表示,或称中间语言。程序进行词法分析和语法分析以后,将程序转换成中间代码,这一转换的作用是使程序的结构更加简单和规范。中间代码生成操作是一个中间过程,与用户无关。
  4. 代码优化。代码优化是指对程序进行多种等价变换,使得变换后的程序能生成更有效的目标代码。用户可以在编译程序时设置代码优化的参数,可以针对不同的环境和设置进行优化。
  5. 目标代码生成。目标代码生成指的是产生可以执行的应用程序,这是编译的最后一个步骤。生成的程序是二进制形式的机器语言,用户只能运行这个程序,而不能打开这个文件查看程序的代码。

简介

pkg-config 主要解决软件库的依赖问题,特别是在不同的平台,安装的软件目录不同的情况下,可以很优雅地解决。这一切都是自动的,不用担心库文件放在什么地方。

1
pkg-config - Return metainformation about installed libraries

比如对于同样安装了gtk的系统而言,使用下来命令

1
pkg-config --libs --cflags gtk+-2.0

MacOSX输出为:

1
-D_REENTRANT -I/usr/local/Cellar/gtk+/2.24.31_1/include/gtk-2.0 -I/usr/local/Cellar/gtk+/2.24.31_1/lib/gtk-2.0/include -I/usr/local/Cellar/pango/1.40.14/include/pango-1.0 -I/usr/local/Cellar/harfbuzz/1.7.5/include/harfbuzz -I/usr/local/Cellar/graphite2/1.3.10/include -I/usr/local/Cellar/pango/1.40.14/include/pango-1.0 -I/usr/local/Cellar/atk/2.26.1/include/atk-1.0 -I/usr/local/Cellar/cairo/1.14.12/include/cairo -I/usr/local/Cellar/pixman/0.34.0_1/include/pixman-1 -I/usr/local/Cellar/fontconfig/2.12.6/include -I/usr/local/opt/freetype/include/freetype2 -I/usr/local/Cellar/libpng/1.6.34/include/libpng16 -I/usr/local/Cellar/gdk-pixbuf/2.36.11/include/gdk-pixbuf-2.0 -I/usr/local/Cellar/libpng/1.6.34/include/libpng16 -I/usr/local/Cellar/glib/2.54.3/include/glib-2.0 -I/usr/local/Cellar/glib/2.54.3/lib/glib-2.0/include -I/usr/local/opt/gettext/include -I/usr/local/Cellar/pcre/8.41/include -L/usr/local/Cellar/gtk+/2.24.31_1/lib -L/usr/local/Cellar/pango/1.40.14/lib -L/usr/local/Cellar/atk/2.26.1/lib -L/usr/local/Cellar/cairo/1.14.12/lib -L/usr/local/Cellar/gdk-pixbuf/2.36.11/lib -L/usr/local/Cellar/glib/2.54.3/lib -L/usr/local/opt/gettext/lib -lgtk-quartz-2.0 -lgdk-quartz-2.0 -lpangocairo-1.0 -lpango-1.0 -latk-1.0 -lcairo -lgdk_pixbuf-2.0 -lgio-2.0 -lgobject-2.0 -lglib-2.0 -lintl -Wl,-framework -Wl,CoreFoundation

CentOS输出为:

1
-pthread -I/usr/include/gtk-2.0 -I/usr/lib64/gtk-2.0/include -I/usr/include/atk-1.0 -I/usr/include/cairo -I/usr/include/gdk-pixbuf-2.0 -I/usr/include/pango-1.0 -I/usr/include/glib-2.0 -I/usr/lib64/glib-2.0/include -I/usr/include/harfbuzz -I/usr/include/freetype2 -I/usr/include/pixman-1 -I/usr/include/libpng15 -I/usr/include/libdrm  -lgtk-x11-2.0 -lgdk-x11-2.0 -latk-1.0 -lgio-2.0 -lpangoft2-1.0 -lpangocairo-1.0 -lgdk_pixbuf-2.0 -lcairo -lpango-1.0 -lfontconfig -lgobject-2.0 -lglib-2.0 -lfreetype

可以看出还是有很大差别的,所以对于下面的示例程序:

1
2
3
4
```

编译的时候,直接使用下面的命令即可,而不用关注操作系统。

gcc -o test main.c pkg-config --libs --cflags gtk+-2.0


没有规矩不成方圆 sort

Linux sort 命令用于将文本内容进行排序。

官方定义为:

sort - sort lines of text files

语法

1
2
$ sort [OPTION]... [FILE]...
$ sort [OPTION]... --files0-from=F

常用的参数为

  • -c 检查文件是否已经按照顺序排序。
  • -u 意味着是唯一的(unique),输出的结果是去完重了的。
  • -r 以相反的顺序来排序。
  • -k field1[,field2] 按指定的列进行排序。

这里假定测试文件名为testfile

1
2
3
4
5
6
7
LiSi            80

ZhangSan 70

WangWu 90

MaLiu 88

默认无参数

在使用 sort 命令以默认的式对文件的行进行排序,命令如下:

1
2
3
4
5
6
7
8
$ sort testfile 



LiSi 80
MaLiu 88
WangWu 90
ZhangSan 70

sort 命令默认情况下将第一列以 ASCII 码的次序排列,并将结果输出到标准输出。

根据第N列排序

对于测试文件而言,或许我们更希望使用数字来统计排序,此时可以使用-k N参数,其中N为列数

1
2
3
4
5
6
7
8
$  sort testfile -k 2



ZhangSan 70
LiSi 80
MaLiu 88
WangWu 90

指定分隔符,进行排列

此时默认的分隔符为空格,如果是其他分隔符,比如分毫

检查是否已经排序

在某些情况下,或许只想看看文件是否已经排序,使用-c参数 :

1
2
$  sort -c testfile
sort: testfile:2: disorder

如果没有排序会有输出,而排序的话就没有输出。

逆序排列

如果希望看一下数字从高到低的培训,使用-r参数:

1
2
3
4
5
$  sort testfile -k 2  -r
WangWu 90
MaLiu 88
LiSi 80
ZhangSan 70

对一个使用冒号分隔的文件的第二项进行排序

$ sort -t: -k 2 names.txt

对使用tab分隔的第三项进行排序**(department_id),**并去掉重复项

$ sort -t: -u -k 3 names.txt

passwd文件的第三项进行排序**(userid)**

$ sort -t: -k 3n /etc/passwd | more

基于ip地址对**/etc/hosts**文件排序

$ sort -t . -k 1,1n -k 2,2n -k 3,3n -k 4,4n /etc/hosts

与其它命令组合在一起使用

ps –ef | sort : 对进程列表进行排序

ls -al | sort +4n : 使用升序对ls -al的输出以文件大小进行排序(第5项)

ls -al | sort +4nr : 使用降序对ls -al的输出以文件大小进行排序(第5项)