Python模块应用 (linecache)

linecache

linecache是专门支持读取大文件,而且支持行式读取的函数库。 linecache 预先把文件读入缓存起来,后面如果你访问该文件的话就不再从硬盘读取。对于大文件的读取效率还不错

Help on module linecache:

NAME
    linecache - Cache lines from files.

FILE
    /usr/local/lib/python2.7/linecache.py

MODULE DOCS
    http://docs.python.org/library/linecache

DESCRIPTION
    This is intended to read lines from modules imported -- hence if a filename
    is not found, it will look down the module search path for a file by
    that name.

FUNCTIONS
    checkcache(filename=None)
        Discard cache entries that are out of date.
        (This is not checked upon each call!)

    clearcache()
        Clear the cache entirely.

    getline(filename, lineno, module_globals=None)

DATA
    __all__ = [‘getline‘, ‘clearcache‘, ‘checkcache‘]

help(linecache)

常用的方法:

linecache.getlines(filename,)  #接收一个文件对象,返回一个列表,列表中的每个元素就是文件中的一行. 和readlines()一样
linecache.getline(filename,lineno)  #接收一个文件对象和一个行数,返回指定行数对应的行内容

>>> linecache.getlines(‘/etc/passwd‘)
[‘root:x:0:0:root:/root:/bin/bash\n‘, ‘bin:x:1:1:bin:/bin:/sbin/nologin\n‘, ‘daemon:x:2:2:daemon:/sbin:/sbin/nologin\n‘, ‘adm:x:3:4:adm:/var/adm:/sbin/nologin\n‘, ‘lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin\n‘, ‘sync:x:5:0:sync:/sbin:/bin/sync\n‘, ‘shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown\n‘, ‘halt:x:7:0:halt:/sbin:/sbin/halt\n‘, ‘mail:x:8:12:mail:/var/spool/mail:/sbin/nologin\n‘, ‘uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin\n‘, ‘operator:x:11:0:operator:/root:/sbin/nologin\n‘, ‘games:x:12:100:games:/usr/games:/sbin/nologin\n‘, ‘gopher:x:13:30:gopher:/var/gopher:/sbin/nologin\n‘, ‘ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin\n‘, ‘nobody:x:99:99:Nobody:/:/sbin/nologin\n‘, ‘dbus:x:81:81:System message bus:/:/sbin/nologin\n‘, ‘vcsa:x:69:69:virtual console memory owner:/dev:/sbin/nologin\n‘, ‘abrt:x:173:173::/etc/abrt:/sbin/nologin\n‘, ‘haldaemon:x:68:68:HAL daemon:/:/sbin/nologin\n‘, ‘ntp:x:38:38::/etc/ntp:/sbin/nologin\n‘, ‘saslauth:x:499:76:"Saslauthd user":/var/empty/saslauth:/sbin/nologin\n‘, ‘postfix:x:89:89::/var/spool/postfix:/sbin/nologin\n‘, ‘sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin\n‘, ‘tcpdump:x:72:72::/:/sbin/nologin\n‘, ‘ansibletest:x:500:500::/home/ansibletest:/bin/bash\n‘, ‘mysql:x:27:27:MySQL Server:/var/lib/mysql:/bin/bash\n‘, ‘zabbix:x:498:499:Zabbix Monitoring System:/var/lib/zabbix:/sbin/nologin\n‘, ‘apache:x:48:48:Apache:/var/www:/sbin/nologin\n‘, ‘elasticsearch:x:497:498:elasticsearch user:/home/elasticsearch:/sbin/nologin\n‘, ‘redis:x:496:497:Redis Server:/var/lib/redis:/sbin/nologin\n‘, ‘pythons:x:501:501::/home/pythons:/bin/bash\n‘]

linecache.getlines()

>>> linecache.getline(‘/etc/passwd‘,10)
‘uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin\n‘
>>> linecache.getline(‘/etc/passwd‘,5)
‘lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin\n‘

linecache.getline()

时间: 2024-10-04 03:59:18

Python模块应用 (linecache)的相关文章

python-学习笔记之-Day5 双层装饰器 字符串格式化 python模块 递归 生成器 迭代器 序列化

1.双层装饰器 #!/usr/bin/env python # -*- coding: utf-8 -*- # author:zml LOGIN_INFO = False IS_ADMIN = False   def check_log(func): def inner(): res = func() if LOGIN_INFO: print('验证成功!') return res else: print('验证失败!') return inner   def check_admin(func)

Python模块的交叉引用问题分析

实际项目中遇到python模块相互引用问题,查资料,说是通过import局部导入的方式可以避免错误,资料如附录所述. 但更改后测试还是会出错,很疑惑!? 如果哪位读者有好的解决方法,敬请留言说明,谢谢. 所以,最好的方法是不进行交叉引用,如果需要就单独分一个模块出来. 附录:Python模块的交叉引用问题解读:How can I have modules that mutually import each other? 有下面两个文件相互引用,Python解释器报错. foo.py: from

python模块以及导入出现ImportError: No module named 'xxx'问题

python模块以及导入出现ImportError: No module named 'xxx'问题 python中,每个py文件被称之为模块,每个具有__init__.py文件的目录被称为包.只要模 块或者包所在的目录在sys.path中,就可以使用import 模块或import 包来使用 如果你要使用的模块(py文件)和当前模块在同一目录,只要import相应的文件名就好,比 如在a.py中使用b.py:  import b 但是如果要import一个不同目录的文件(例如b.py)该怎么做

python模块搜索路径

1.电脑版 (1).python安装目录中\Lib\site-packages\下建立*.pth文件,写入模块路径 (2).添加环境变量:变量名:pythonpath;变量值:模块(文件夹)路径 ,若有多个,用半角分号";"隔开 2.手机版 在resource\site.py文件中添加代码段 import syssys.path.append("模块(文件夹)路径") 发现:第一个参数都是C:\\resource 我的理解: 程序安装盘下的site.py指定模块路径

4.python模块

python 字符串 一.注释 在python中的注释分为单行注释和多行注释    (1)单行注释:为在语句的前边加"#" 例子: #!/usr/bin/env python a = 123 print a #print a #print a #print a 执行结果如下: [[email protected] ~]# python a.py 123  (2)多行注释:可以用3对单引号(比如:''' 注释内容''') 或是3对双引号(比如:"""注释内容

使用 from import方法导入Python模块

比如我们导入一个数学计算的模块 math: >>> import math>>> print math<module 'math' (built-in)>>>>>>> print math.pi #导出圆周率的值3.14159265359>>> 我们导入math模块,在python模块学习中我们会知道,这样做会得到名math的对象,这个模块对象包含了pi这样的常量,以及一些其它的方法. 我们如果直接访问

Python 八、Python模块

一.python文件概述 1.python模块概述 可以将代码量较大的程序分割成多个有组织的.彼此独立但又能互相交互的代码片段,这些自我包含的有组织的代码段就是模块 模块在物理形势上表现为以.py结尾的代码文件 一个文件被看作一个独立的模块,一个模块也可以被看作是一个文件 模块的文件名就是模块的名字加上扩展名(.py) 每个模块都有自己的名称空间 python允许导入其它模块以实现代码重用,从而也实现了将独立的代码文件组织成更大的程序系统 python中,模块也是对象 在一个模块的顶层定义的所有

python 学习第五天,python模块

一,Python的模块导入 1,在写python的模块导入之前,先来讲一些Python中的概念性的问题 (1)模块:用来从逻辑上组织Python代码(变量,函数,类,逻辑:实现一个功能),本质是.py结尾的python文件(文件名:test.py,对应的模块名:test) (2)包:用来从逻辑上组织模块的,本质就是一个目录(必须带有一个__init__.py文件) 2,导入的方法 (1)import module_name导入某个模块 (2)import module_name,module2_

七、Python模块和包

Python模块 Python模块是组织代码的基本方式 Python的脚本都是用扩展名为py的文本文件保存的,一个脚本可以单独运行,也可以导入另一个脚本中运行.当脚本被导入运行时,将其称为模块 cat test.py #!/usr/bin/python #coding:utf-8 from __future__ import division def a(x,y): print x+y def b(x,y): print x*y cat new.py #!/usr/bin/python impo