leetcode 195. 第十行
# cat file.txt | head -n 10 | tail -n 1cat 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-4567123 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个,否则有问题。