【awk】指定多分隔符
https://blog.csdn.net/whatday/article/details/90415997
其实呢,通过在awk中指定两个记录分隔符(空格和:),即可一次性的提取出width和height后面的值,在awk中支持多个记录分隔符的写法如下
# echo "width:720 height:360" | awk -F'[ :]' '{print $2,$4}' 720 360
不过,一般像下面这样写,多一个加号表明将连续出现的记录分隔符当做一个来处理
# echo "width:720 height:360" | awk -F'[ :]+' '{print $2,$4}' 720 360
可以尝试在height前面再增加一个空格,各位可以自己去命令行下尝试下
# echo "width:720 height:360" | awk -F'[ :]' '{print $2,$4}' 720 height # echo "width:720 height:360" | awk -F'[ :]+' '{print $2,$4}' 720 360
注意:
在awk中,当记录分隔符指定为空字符串时,awk会将多个连续的空白看做一个单一的记录分隔符。此外,awk还会忽略开头和结尾处的空白。
awk支持正则表达式形式的记录分隔符,你可以改成其它的正则表达式来进行测试。上面虽然介绍了awk中使用多个记录分隔符的写法,但是这些记录分隔符都是单个字符,如果记录分隔符是个字符串怎么办呢?
之前说过,awk支持正则表达式形式的记录分隔符,那就写个正则表达式就好,比如要指定分隔符为one和two
# echo "i have two apples and one banana" | awk -F'one|two' '{for(i=1;i<=NF;i++)print i,"="$i}' 1 =i have 2 = apples and 3 = banana
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2021-06-30 【Python】mysql数据库读取
2021-06-30 【dataframe 】去重函数drop_duplicates使用方法
2021-06-30 【panda】只获取CSV文件的某几列,usecols参数
2021-06-30 【panda】直接读取数据库的表,read_sql函数
2021-06-30 【panda】处理读取文件时以0开头缺失,或数字变成科学计数法,read_csv参数增加dtype=object