//目录

leetcode shell

leetcode 195. 第十行

# cat file.txt | head -n 10 | tail -n 1
cat file.txt | tail -n +10 | head -n 1

第一种是先取出前10行,然后取出最后一行。(但是不足10行,也可以取出最后一行)

正解:

tail -n +K :从第K行取出所有

然后取出第一行

 

leetcode 193. 有效电话号码

给定一个包含电话号码列表(一行一个电话号码)的文本文件 file.txt,写一个 bash 脚本输出所有有效的电话号码。

你可以假设一个有效的电话号码必须满足以下两种格式: (xxx) xxx-xxxx 或 xxx-xxx-xxxx。(x 表示一个数字)

你也可以假设每行前后没有多余的空格字符。

示例:

假设 file.txt 内容如下:

987-123-4567
123 456 7890
(123) 456-7890

你的脚本应当输出下列有效的电话号码:

987-123-4567
(123) 456-7890

可以用到我昨天写的正则表达式;grep 只支持基础正则表达式,egrep 支持扩展正则表达式,两者是有区别的。

egrep '(^[0-9]{3}-|^\([0-9]{3}\) )[0-9]{3}-[0-9]{4}$' ./file.txt

 

leetcode 192. 统计词频

egrep '[a-z]*' ./words.txt -o | sort | uniq -c | sort -r | awk '{print $2" "$1}'

egrep -o :列出匹配到项

sort :排序

uniq -c :去掉重复单词,得到group,"出现次数 单词"形式;-c 是count

sort -r : 反向排序

awk '{print $2 " " $1}' :单词,次数

 

tip:数据很弱,-r 反向排序就不对了,说明样例一个单词,不超过10个,否则有问题。

posted @ 2019-01-16 18:06  小草的大树梦  阅读(172)  评论(0编辑  收藏  举报