Shell中实现字符串反转方法分享
2014-12-01 00:00
531 查看
在做关键词清洗过程中,需要将一类不符合某个字结尾的词过滤出来,思路是把这一批词按最后一个字排序,于是想到了先把这些词反转一下,如把12345转为54321,好像以前在夜息的文章里看过用shell可以实现,就百度了一下,找到几个可行的解决方法,现记录一下。
shell实现字符串反转,一句命令搞定!
命令的:
python 的:
sed 的:
awk 的:
纯 bash 的:
c 的:
shell实现字符串反转,一句命令搞定!
cat keywords.txt|while read line;do echo $line|rev;done
命令的:
echo 12345|rev 54321
python 的:
echo 12345|python -c ‘print raw_input()[::-1]'
sed 的:
echo 12345|sed ‘/\n/!G;s/\(.\)\(.*\n\)/&\2\1/;//D;s/.//'
awk 的:
echo 12345|awk ‘BEGIN{FS=””}{for(a=NF;a>0;a–)printf(“%s”,a==1?$a”\n”:$a)}'
纯 bash 的:
echo 12345|{ read;for((i=${#REPLY};i>0;i–))do echo -n “${REPLY:$[i-1]:1}”;done;echo; };
c 的:
gcc -o a -O2 -x c <(cat <<! #include <stdio.h> #include <stdlib.h> #include <string.h> int main(int argc,char *argv[]) { if(argc != 2) { printf("%s reverse lines of a string\n",argv[0]); exit(1); } int i=0; char *p; p=argv[1]; i=strlen(argv[1])-1; for(i;i>=0;i--) { printf("%s%s",&p[i],(i==0)?"\n":""); p[i]='\0'; } })&& ./a "12345" ;rm -f a
相关文章推荐
- Shell中实现字符串反转方法分享
- Shell中实现字符串反转方法
- 用C语言实现字符串反转函数strrev的经典方法
- C语言两种方法实现字符串反转
- php实现字符串反转输出的方法
- 定义一个静态成员方法,该方法实现字符串反转
- 实现数组反转及字符串反转的方法
- C#--第九周 任务2--定义一个静态成员方法,该方法实现字符串反转
- C语言字符串反转实现【采用头指针和尾指针方法完成】
- 编写一个方法用于验证指定的字符串是否为反转字符,返回true和false。请用递归算法实现
- php实现字符串反转输出的方法
- 三种JAVA常用实现字符串反转(Reverse)的方法
- [Python]实现字符串反转的三个方法
- javascript 实现字符串反转的三种方法
- 用C语言实现字符串反转函数strrev的经典方法
- shell 脚本中实现字符串大小写不敏感的比较方法
- PHP中实现中文字符串反转避免乱码的方法
- PHP中实现中文字符串反转避免乱码的方法
- 字符串实现反转的几种方法
- 【字符串反转总结】Java中七种方法实现