python判断字符串出现的次数_判断字符串里每个字符的次数(python,shell,perl)

有一个请求,判断字符串里每个字符出现的次数

python

解体思路:列表的count方法

Python 2.6.6 (r266:84292, Aug 9 2016, 06:11:56)

[GCC 4.4.7 20120313 (Red Hat 4.4.7-17)] on linux2

Type "help", "copyright", "credits" or "license" for more information.

>>> var="dsvsdwefsdagafoijkafdgweodfas"#要判断的字符串

>>> varlist=list(var)#列表化字符串

>>> print varlist

['d', 's', 'v', 's', 'd', 'w', 'e', 'f', 's', 'd', 'a', 'g', 'a', 'f', 'o', 'i', 'j', 'k', 'a', 'f', 'd', 'g', 'w', 'e', 'o', 'd', 'f', 'a', 's']

>>> sinlist=[]#要一个空列表

>>> for letter in varlist:#排除重复字符,把不重复的字符装入新列表。

... if letter not in sinlist:

... sinlist.append(letter)

...

>>> print sinlist

['d', 's', 'v', 'w', 'e', 'f', 'a', 'g', 'o', 'i', 'j', 'k']#这是不重复的列表

>>> for letter in sinlist:#在新列表里循环,用list.count的方法确认每个字符在旧列表出现的次数

... print "letter name is " + letter + " count: " + str(varlist.count(letter))

...

letter name is d count: 5

letter name is s count: 4

letter name is v count: 1

letter name is w count: 2

letter name is e count: 2

letter name is f count: 4

letter name is a count: 4

letter name is g count: 2

letter name is o count: 2

letter name is i count: 1

letter name is j count: 1

letter name is k count: 1

>>> quit()

shell

解题思路:字符串长度,cut和grep

[myname@mypc Desktop]$ var="dsvsdwefsdagafoijkafdgweodfas"#要判断的字符串

[myname@mypc Desktop]$ endnum=`echo -n $var|wc -c`#计算出字符串长度,记住这里用的是echo -n为了排除换行符

[myname@mypc Desktop]$ echo $endnum

29

[myname@mypc Desktop]$ i=1#赋值一个int变量

[myname@mypc Desktop]$ while [ $i -le $endnum ];do echo $var|cut -c $i;i=`expr $i + 1`;done>tempfile#用一个循环把每个字符打印出来,重定向一个临时文件

[myname@mypc Desktop]$ cat tempfile

d

s

v

s

d

w

e

f

s

d

a

g

a

f

o

i

j

k

a

f

d

g

w

e

o

d

f

a

s

[myname@mypc Desktop]$ i=1

[myname@mypc Desktop]$ while [ $i -le $endnum ];do letter=`echo $var|cut -c $i`;count=`grep $letter tempfile|wc -l`;echo "letter is $letter,count is $count";i=`expr $i + 1`;done|sort -u

letter is a,count is 4

letter is d,count is 5

letter is e,count is 2

letter is f,count is 4

letter is g,count is 2

letter is i,count is 1

letter is j,count is 1

letter is k,count is 1

letter is o,count is 2

letter is s,count is 4

letter is v,count is 1

letter is w,count is 2

#再用一个循环去判断每个字符出现的次数

详细解析一下这个循环

while [ $i -le $endnum ]#当i小于或等于字符串长度的时候循环

do

letter=`echo $var|cut -c $i`#取出字符名字

count=`grep $letter tempfile|wc -l`#用grep取出tempfile里字符出现的行数

echo "letter is $letter,count is $count"#打印出结果

i=`expr $i + 1`#i递增

done|sort -u#sort -u是去重,因为里面有重复的结果

perl

perl我不是很懂,查了半天,对于perl我的评价是好用是好用,但是固有写法中符号用的太多,很容易让初学者看起来像天书

解题思路:字符转数组split,替换s/var/var/g,听说还能用hash解,不会中

[myname@mypc Desktop]$ perl -e 'my $var="dsfesfsavcxgsatewqrsadfsaga";#赋值var

> my @varlist=split("",$var);#转化var为数组varlist

> my @grepaf = grep{++$count{$_}<2} @varlist;#这个网上抄来的去重,原理是循环数组varlist,当计数不重复的时候记录,重复不计入数组grepaf

> foreach $a (@grepaf) #在不重复的数组里循环

> { $count=$var=~s/$a/$a/g;#这个意思是说替换变量a为变量a,然后替换的次数就成了count的值。

> print $a," is ",$count,"\n"; }'#打印结果

d is 2

s is 6

f is 3

e is 2

a is 5

v is 1

c is 1

x is 1

g is 2

t is 1

w is 1

q is 1

r is 1

对比下来,python的方法最简单,shell的最多步骤,perl写的最复杂(perl自带的符号太多了,学习这些符号好累)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值