国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Python:高效計算大文件中的最長行的長度

2019-11-14 17:45:28
字體:
來源:轉載
供稿:網友

在操作某個很多進程都要頻繁用到的大文件的時候,應該盡早釋放文件資源(f.close())

前2種方法主要用到了列表解析,性能稍差,而最后一種使用的時候生成器表達式,相比列表解析,更省內存

列表解析和生成器表達式很相似:

列表解析

[exPR for iter_var in iterable if cond_expr]

生成器表達式

(expr for iter_var in iterable if cond_expr)

 方法1:最原始

longest = 0f = open(FILE_PATH,"r")allLines = [line.strip() for line in f.readlines()]f.close()for line in allLines:    linelen = len(line)    if linelen>longest:        longest = linelen

方法2:簡潔

f = open(FILE_PATH,"r")allLineLens = [len(line.strip()) for line in f]longest = max(allLineLens)f.close()

缺點:一行一行的迭代f的時候,列表解析需要將文件的所有行讀取到內存中,然后生成列表

 方法3:最簡潔,最節省內存

f = open(FILE_PATH,"r")longest = max(len(line) for line in f)f.close()

或者

print max(len(line.strip()) for line in open(FILE_PATH))

參考資料:Python核心編程(第8章)

原文地址:曾是土木人

轉載請注明出處:http://m.survivalescaperooms.com/hongfei/p/3768207.html


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 木里| 隆安县| 荔浦县| 临高县| 宕昌县| 安乡县| 大安市| 光山县| 高碑店市| 丹棱县| 虞城县| 竹溪县| 兴城市| 大石桥市| 旺苍县| 安福县| 安康市| 常熟市| 中卫市| 蒙阴县| 洱源县| 二连浩特市| 耒阳市| 海口市| 昭通市| 图木舒克市| 佳木斯市| 济阳县| 肇源县| 饶河县| 唐山市| 怀集县| 崇义县| 阿拉尔市| 达州市| 图们市| 淄博市| 大同市| 琼中| 固原市| 乡城县|