zoukankan      html  css  js  c++  java
  • python之enumerate

    http://eagletff.blog.163.com/blog/static/116350928201266111125832/
    一般情况下,如果要对一个列表或者数组既要遍历索引又要遍历元素时,可以用enumerate

    比如:
    for index,value in enumerate(list):
         print index,value
    当然也可以
    for i in range(0,len(list)):
         print i,list[i]
    相比较而言,前者更简练
    另外一种使用情况,当要计算文件的行数的时候,可以这样写:
    lineNum = len(open(fileName,'r').readlines())
    不过如果文件巨大,这种方式可能会造成严重问题,比如机器挂掉
    这个时候可以使用enumerate,python cookbook里举出了这样的例子
    lineNum = -1
    for count,line in enumerate(open(fileName,'r')):
         print count
         lineNum+=1
    print lineNum
    试过用上面的脚本来统计一个1GB大小的log文件(最后统计出来大约有18000000行),运行脚本的时候,CPU占用率比较高(看来是做计算的比较多),但是脚本用到的内存不多,显示的python占用内存为5M多
    不过如果用readlines的方法,内存飙到了200M
    将文本文件的全部内容按照分行,作为一个列表读出的5种方法 
    list_of_all_the_lines = file_object.readlines(  )          
    list_of_all_the_lines = file_object.read(  ).splitlines(1)  
    list_of_all_the_lines = file_object.read().splitlines(  ) 
    list_of_all_the_lines = file_object.read(  ).split(' ') 
    list_of_all_the_lines = list(file_object)

  • 相关阅读:
    sql优化
    什么是泛型
    Http Status 400
    Hadoop搭建伪分布式 & 上传和下载文件
    Centos64 安装指南
    个人感悟
    zabbix4.0部署
    MySQL引擎
    mysql正则表达式
    k8s自动补全命令
  • 原文地址:https://www.cnblogs.com/cdsj/p/3552237.html
Copyright © 2011-2022 走看看