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

首頁 > 編程 > Python > 正文

Python高級應用實例對比:高效計算大文件中的最長行的長度

2020-02-23 05:26:02
字體:
來源:轉載
供稿:網友

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

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

列表解析

[expr for iter_var in iterable if cond_expr]

生成器表達式

(expr for iter_var in iterable if cond_expr)

 方法1:最原始

代碼如下:
longest = 0
f = 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))

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 广州市| 尉犁县| 墨江| 尼勒克县| 拉孜县| 文昌市| 安乡县| 比如县| 天水市| 蓬莱市| 蚌埠市| 望谟县| 襄城县| 辽阳县| 潼南县| 阿瓦提县| 额尔古纳市| 鄂州市| 积石山| 舞阳县| 吉水县| 嘉禾县| 遂昌县| 潍坊市| 墨玉县| 丹江口市| 和田县| 浦东新区| 阿拉尔市| 湖州市| 汉阴县| 台东市| 依安县| 公安县| 丰县| 崇礼县| 玉门市| 渭源县| 修武县| 江城| 兴化市|