您的位置:首页 > 运维架构 > Shell

使用bash内部的字符串处理

2014-11-12 08:13 211 查看
http://www.linuxeden.com/html/develop/20100113/70060.html
经常看到一些脚本中, 做一些简单的字符串处理/计算字符串长度,也动用管道+ awk/sed/cut等相对重量级工具:),其实大可不必, 因为bash本身就自带一些简单字符串处理功能, 这样至少可以减少重新fork一个进程来做字符串处理的开销, 也算为服务器减排co2做一些贡献吧:)

# 定义几个变量用于测试目的
FILE_NAME="/usr/local/app/world.txt"
TIME_NOW="`date +"%Y%m%d%H%M%S"`"
# 1. 取字符串的子串, 比如说从TIME_NOW分别取出日期和时间
DATE_TODAY="${TIME_NOW:0:8}" # ${var:beg_pos:sub_str_length}, beg_pos是子串的起始位置(从0开始), sub_str_length为子串长度
TIME_TODAY="${TIME_NOW:8:6}"
# 或者
TIME_TODAY="${TIME_NOW:8}" # sub_str_length为0表示到源字符串的结尾

# 取FILE_NAME中的文件名world.txt(不包括路径), 很多童鞋会马上想到basename, 或者一些类似于正则匹配的操作
${FILE_NAME##*/} # 相当于basename ${FILE_NAME},即删除按从左至右,匹配一直到最后一个/之间的子串
${FILE_NAME%/*} # 相当与dirname, 即删除按从右至左方向开始,匹配到第一个/之间的子串
${FILE_NAME#*/} # 从左至右, 删除第一个/及左边的子串
${FILE_NAME%%/*} # 从右至左, 删除至最后一个/及右边的子串

# 2. 字符串替换
${FILE_NAME/world.txt/hello.txt} # 把第一个world.txt替换成hello.txt
${FILE_NAME//a/A} # 把所有的a替换成A

# 3. 计算字符串长度
${#FILE_NAME} # 计算FILE_NAME的长度
ARRAY=(abc defg hijklmn)
${#ARRAY} # 计算这个数组的维数
${#ARRAY[2]} # 计算这个数组第三个元素的长度

对于字符串的处理, 暂时能想到这么一些了, 接触这些东西, 也是因为偶尔会看看操作系统的一些脚本都这样用, 感觉比较专业一些, 自己以前处理一些字符串的时候, 也会用awk/sed加上管道等等, 感觉会略显业余同时确实会在cpu开销上作出一些贡献,虽然只是些许:)
结束语:
现在全球都在谈节能减排, 我们能做些什么呢? 数据显示, 目前信息和通信技术领域造成的二氧化碳排放量已占全球二氧化碳排放总量的大约2%, 在2007年,全球的电脑、打印机、手机和各种小型的IT产品共产生了8.3亿吨的碳排放量,这一数字与航空业的碳排量相当。 在写脚本的时候,如何有效使用能够更加减少cpu的负载,如何更加能提高脚本的执行速度, 请继续关注《我也要低碳》系列。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: