python统计一个文本中重复行数的方法
2014-11-19 00:00
826 查看
本文实例讲述了python统计一个文本中重复行数的方法。分享给大家供大家参考。具体实现方法如下:
比如有下面一个文件
2
3
1
2
我们期望得到
2,2
3,1
1,1
解决问题的思路:
出现的文本作为key, 出现的数目作为value,然后按照value排除后输出
最好按照value从大到小输出出来,可以参照:
代码如下:
补充说明:
1. python的dict对象的两个方法:
items方法将所有的字典项以列表的方式返回, 这些列表项中每一项都来自于(键, 值)
iteritems方法与items的作用大致相同, 但是返回一个迭代器对象而不是列表
2. python的内建函数sorted
希望本文所述对大家的Python程序设计有所帮助。
比如有下面一个文件
2
3
1
2
我们期望得到
2,2
3,1
1,1
解决问题的思路:
出现的文本作为key, 出现的数目作为value,然后按照value排除后输出
最好按照value从大到小输出出来,可以参照:
in recent Python 2.7, we have new OrderedDict type, which remembers the order in which the items were added. >>> d = {"third": 3, "first": 1, "fourth": 4, "second": 2} >>> for k, v in d.items(): ... print "%s: %s" % (k, v) ... second: 2 fourth: 4 third: 3 first: 1 >>> d {'second': 2, 'fourth': 4, 'third': 3, 'first': 1}To make a new ordered dictionary from the original, sorting by the values: >>> from collections import OrderedDict >>> d_sorted_by_value = OrderedDict(sorted(d.items(), key=lambda x: x[1]))The OrderedDict behaves like a normal dict: >>> for k, v in d_sorted_by_value.items(): ... print "%s: %s" % (k, v) ... first: 1 second: 2 third: 3 fourth: 4 >>> d_sorted_by_value OrderedDict([('first': 1), ('second': 2), ('third': 3), ('fourth': 4)])
代码如下:
#coding=utf-8 import operator f = open("f.txt") count_dict = {} for line in f.readlines(): line = line.strip() count = count_dict.setdefault(line, 0) count += 1 count_dict[line] = count sorted_count_dict = sorted(count_dict.iteritems(), key=operator.itemgetter(1), reverse=True) for item in sorted_count_dict: print "%s,%d" % (item[0], item[1])
补充说明:
1. python的dict对象的两个方法:
items方法将所有的字典项以列表的方式返回, 这些列表项中每一项都来自于(键, 值)
iteritems方法与items的作用大致相同, 但是返回一个迭代器对象而不是列表
2. python的内建函数sorted
>>> help(sorted) Help on built-in function sorted in module __builtin__: sorted(...) sorted(iterable, cmp=None, key=None, reverse=False) --> new sorted list
希望本文所述对大家的Python程序设计有所帮助。
相关文章推荐
- python统计一个文本中重复行数的方法
- python统计文本字符串里单词出现频率的方法
- Python判断文本中消息重复次数的方法
- 统计一个大文本行数的几种方法以及效率统计(二)
- python统计文本字符串里单词出现频率的方法
- Python简单实现查找一个字符串中最长不重复子串的方法
- python 一个简单的依靠文件来判断key是否重复的方法
- 【笔记】一个分组统计的python与sql方法
- 当统计一个有重复的字段可以用这个方法
- 统计一个大文本行数的几种方法以及效率统计(一)
- 一没考虑单词重复,二没考虑先输入空格,三没考虑后面连续输空格,方法见空格将空格前面的当成一个字符串,字符串比较是否相同,再统计
- Python判断文本中消息重复次数的方法
- 使用python Tkinter制作一个可以生成重复文本片段的小工具
- Python用于文本分析的一个demo—统计文档中只出现一次的字符
- [置顶] Python生成词云图,TIIDF方法文本挖掘: 词频统计,词云图
- Python实现统计文本文件字数的方法
- 一个简单的程序,统计文本文档中的单词和汉字数,逆序排列(出现频率高的排在最前面)。python实现。
- Python3 写一个简单的文本统计脚本
- python统计列表元素重复次数的N中方法
- 消除表中重复记录的一个取巧方法