# -*- coding: UTF-8 -*- # 作者:huanhuilong # 标题:Python 编码规范 # 描述:输出MarkDown风格列表结构的 “学习 Python 编码规范以及相关工具和插件” 的介绍信息 def top_words(splits, text, top_n=5): i = 0 word_dict = {} chars = [] while i < len(text): c = text[i] if c in splits: while i+1 < len(text) and text[i+1] in splits: i += 1 word = ''.join(chars).lower() # word_info = word_dict.get(word) # if not word_info: # word_info = {'word': word, 'count': 0} # word_dict[word] = word_info # word_info['count'] += 1 # word_info = word_dict.get(word) # if not word_info: # word_info = {'word': word, 'count': 1} # word_dict[word] = word_info # word_list.append(word_info) # else: # word_info['count'] += 1 word_info = word_dict.get(word, {'word': word, 'count': 0}) word_info['count'] += 1 word_dict[word] = word_info # if not word in word_dict: # word_info = {'word': word, 'count': 0} # word_dict[word] = word_info # word_info['count'] += 1 chars = [] else: chars.append(c) i += 1 word_list = list(word_dict.values()) top_n = min(top_n, len(word_list)) word_list.sort(key=lambda word_info: word_info['count'], reverse=True) return word_list[0:top_n] if __name__ == '__main__': google_style_guide = ''' Every major open-source project has its own style guide: a set of conventions (sometimes arbitrary) about how to write code for that project. It is much easier to understand a large codebase when all the code in it is in a consistent style. “Style” covers a lot of ground, from “use camelCase for variable names” to “never use global variables” to “never use exceptions.” This project (google/styleguide) links to the style guidelines we use for Google code. If you are modifying a project that originated at Google, you may be pointed to this page to see the style guides that apply to that project. This project holds the C++ Style Guide, C# Style Guide, Swift Style Guide, Objective-C Style Guide, Java Style Guide, Python Style Guide, R Style Guide, Shell Style Guide, HTML/CSS Style Guide, JavaScript Style Guide, TypeScript Style Guide, AngularJS Style Guide, Common Lisp Style Guide, and Vimscript Style Guide. This project also contains cpplint, a tool to assist with style guide compliance, and google-c-style.el, an Emacs settings file for Google style. ''' python_style_guides = ''' * Python 代码风格指南', * [google-python-styleguide_zh_cn](https://zh-google-styleguide.readthedocs.io/en/latest/google-python-styleguide/python_style_rules /) * [PEP8](https://legacy.python.org/dev/peps/pep-0008/) * 代码风格和自动完成工具链 * 基本工具 * [pylint](https://pylint.org/) * [autopep8](https://pypi.org/project/autopep8/) * Visual Studio Code Python 开发基本插件 * Pylance * Python Path * Python-autopep8 ''' splits = ['\n', ' ', '-', ':', '/', '*', '_', '(', ')', '"', '”', '“', '[', ']'] tops = top_words(splits, google_style_guide+python_style_guides) print('单词排行榜') print('--------') i = 0 while i < len(tops): top = tops[i] word = top['word'] count = top['count'] print(f'{i+1}. 单词:{word}, 词频:{count}') i += 1