python統(tǒng)計字符串中字母出現(xiàn)次數(shù)代碼實例
代碼如下
dic=dict()d={}s=set()s=’helloworld’(1)d=dict() for x in s: if x not in d.keys(): d[x]=1 else: d[x]=d[x]+1 print(d)(2)d2=dict() for x in s: d2[x]=d2.get(x,0)+1 print(d2)(3)d3=dict() for x in s: d3[x]=s.count(x) print(d3)
上面一共給出了三種方法,均是以字典的形式輸出,但可以看出,通過第二三種的內(nèi)置函數(shù)方法更簡便
def countchar(str):str = str.lower()# 化成小寫ans = []for i in range(26): #列表賦初值 26 個 0ans.append(0)for i in str:if (ord(i) >= ord(’a’) and ord(i) <=ord(’z’)):ans[ord(i) - ord(’a’)] = ans[ord(i) -ord(’a’)] + 1# 統(tǒng)計個數(shù)return ansif __name__ == '__main__':str = input()print(countchar(str))def countchar(st): #定義數(shù)個數(shù)的函數(shù)keys = [chr(i + 97) for i in range(26)]# 生成26個字母的key列表di = dict().fromkeys(keys, 0)# 賦給每個key初始值0new = []# 建立一個新列表用于存放有序的keyst = st.lower()# 將所有輸入的字符改為小寫for s in st: #遍歷字符串di[s] = st.count(s)# 輸出每個字符的個數(shù), 存放到字典里def countchar(str):str = str.lower()# 化成小寫ans = []for i in range(26): #列表賦初值 26 個 0ans.append(0)for i in str:if (ord(i) >= ord(’a’) and ord(i) <=ord(’z’)):ans[ord(i) - ord(’a’)] = ans[ord(i) -ord(’a’)] + 1# 統(tǒng)計個數(shù)return ansif __name__ == '__main__':str = input()print(countchar(str))def countchar(st): #定義數(shù)個數(shù)的函數(shù)keys = [chr(i + 97) for i in range(26)]# 生成26個字母的key列表di = dict().fromkeys(keys, 0)# 賦給每個key初始值0new = []# 建立一個新列表用于存放有序的keyst = st.lower()# 將所有輸入的字符改為小寫for s in st: #遍歷字符串di[s] = st.count(s)# 輸出每個字符的個數(shù), 存放到字典里for k in keys: #遍歷keys, 將其在di中的值添加到新列表, 獲得有序的26個字母的個數(shù)new.append(di[k])return new# 返回存有26個字母個數(shù)的列表if __name__ == '__main__':st = input()# 輸入字符串str1 = ''#定義一個空字符串for s in st: #遍歷輸入的字符串if s.isalpha() != 0: #只有字母才添加到新字符串, 標點忽略不計str1 += sprint(countchar(str1))# 輸出列表for k in keys: #遍歷keys, 將其在di中的值添加到新列表, 獲得有序的26個字母的個數(shù)new.append(di[k])return new# 返回存有26個字母個數(shù)的列表if __name__ == '__main__':st = input()# 輸入字符串str1 = ''#定義一個空字符串for s in st: #遍歷輸入的字符串if s.isalpha() != 0: #只有字母才添加到新字符串, 標點忽略不計str1 += sprint(countchar(str1))# 輸出列表
上面的兩種方法也是輸出字符串的字母出現(xiàn)次數(shù),略有不同的是,這里它先設定了26個字母,并使其對應的初始值為0,然后統(tǒng)計字符串中的各字母出現(xiàn)次數(shù),每個字母出現(xiàn)了多少次,即為其對應的初始值處的值。而沒出現(xiàn)的字母,其對應的值則仍為初始值0
通過上述的幾種方法,我們不難總結(jié)出解決這種問題的思路:從鍵盤隨機輸入一段字符串,然后循環(huán)遍歷字符串,通過循環(huán)字符串中的每一個字符,統(tǒng)計各類字符出現(xiàn)的次數(shù),循環(huán)遍歷字符串
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. vue實現(xiàn)web在線聊天功能2. JAMon(Java Application Monitor)備忘記3. Java Bean與Map之間相互轉(zhuǎn)化的實現(xiàn)方法4. SpringBoot+TestNG單元測試的實現(xiàn)5. Springboot 全局日期格式化處理的實現(xiàn)6. 完美解決vue 中多個echarts圖表自適應的問題7. Python使用urlretrieve實現(xiàn)直接遠程下載圖片的示例代碼8. IntelliJ IDEA設置自動提示功能快捷鍵的方法9. Java使用Tesseract-Ocr識別數(shù)字10. 在Chrome DevTools中調(diào)試JavaScript的實現(xiàn)
