在做關(guān)鍵詞清洗過(guò)程中,需要將一類(lèi)不符合某個(gè)字結(jié)尾的詞過(guò)濾出來(lái),思路是把這一批詞按最后一個(gè)字排序,于是想到了先把這些詞反轉(zhuǎn)一下,如把12345轉(zhuǎn)為54321,好像以前在夜息的文章里看過(guò)用shell可以實(shí)現(xiàn),就百度了一下,找到幾個(gè)可行的解決方法,現(xiàn)記錄一下。
shell實(shí)現(xiàn)字符串反轉(zhuǎn),一句命令搞定!
復(fù)制代碼 代碼如下:
cat keywords.txt|while read line;do echo $line|rev;done
命令的:
復(fù)制代碼 代碼如下:
python 的:
復(fù)制代碼 代碼如下:
echo 12345|python -c ‘print raw_input()[::-1]'
sed 的:
復(fù)制代碼 代碼如下:
echo 12345|sed ‘/\n/!G;s/\(.\)\(.*\n\)/\2\1/;//D;s/.//'
awk 的:
復(fù)制代碼 代碼如下:
echo 12345|awk ‘BEGIN{FS=””}{for(a=NF;a>0;a–)printf(“%s”,a==1?$a”\n”:$a)}'
純 bash 的:
復(fù)制代碼 代碼如下:
echo 12345|{ read;for((i=${#REPLY};i>0;i–))do echo -n “${REPLY:$[i-1]:1}”;done;echo; };
c 的:
復(fù)制代碼 代碼如下:
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
您可能感興趣的文章:- javascript 不用reverse實(shí)現(xiàn)字符串反轉(zhuǎn)的代碼
- SQL Server中通過(guò)reverse取某個(gè)最后一次出現(xiàn)的符號(hào)后面的內(nèi)容(字符串反轉(zhuǎn))
- 使用C語(yǔ)言遞歸與非遞歸實(shí)現(xiàn)字符串反轉(zhuǎn)函數(shù)char *reverse(char *str)的方法
- javascript 實(shí)現(xiàn)字符串反轉(zhuǎn)的三種方法
- java字符串反轉(zhuǎn)示例分享
- 一個(gè)字符串反轉(zhuǎn)函數(shù)可實(shí)現(xiàn)字符串倒序
- php實(shí)現(xiàn)字符串反轉(zhuǎn)輸出的方法
- 字符串反轉(zhuǎn)_JavaScript