bash 字符串处理
2010-02-03 23:00
260 查看
经常看到一些脚本中, 做一些简单的字符串处理/计算字符串长度,也动用管道+ 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的负载,如何更加能提高脚本的执行速度, 请继续关注《我也要低碳》系列。
# 定义几个变量用于测试目的
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的负载,如何更加能提高脚本的执行速度, 请继续关注《我也要低碳》系列。
相关文章推荐
- 16、bash编程之数组介绍、及bash内置字符串处理工具介绍
- Java程序员的Bash实用指南系列之字符串处理(目录)
- BASH 中的字符串处理
- Bash字符串的处理
- 使用bash内部的字符串处理
- #8 bash变量中的字符串处理
- 其他文本处理命令以及bash变量中的一些字符串的处理方法
- BASH 中的字符串处理
- Bash字符串处理(与Java对照) - 19.查找字符的位置
- bash变量字符串处理和数组
- BASH 中的字符串处理
- 数组,字符串处理,mktemp命令,install命令,bash的环境配置文件,程序包编译
- bash中字符串的处理
- Bash中基本的字符串处理
- BASH 中的字符串处理
- Bash字符串处理(获取文件名和后缀名)
- bash的变量中存放的字符串的处理方式
- Linux自学笔记——Bash脚本之数组以及内置字符串处理
- bash脚本字符串处理
- BASH 中的字符串处理