欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

Shell中实现字符串反转方法分享

程序员文章站 2022-06-20 20:18:26
在做关键词清洗过程中,需要将一类不符合某个字结尾的词过滤出来,思路是把这一批词按最后一个字排序,于是想到了先把这些词反转一下,如把12345转为54321,好像以前在夜息的...

在做关键词清洗过程中,需要将一类不符合某个字结尾的词过滤出来,思路是把这一批词按最后一个字排序,于是想到了先把这些词反转一下,如把12345转为54321,好像以前在夜息的文章里看过用shell可以实现,就百度了一下,找到几个可行的解决方法,现记录一下。

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