Python3.0编程总结之二:模块、_name_属性、输入输出、文件方法

Python3 模块

#!/usr/bin/python3
# 文件名: using_sys.py
import sys
 
print('命令行参数如下:')
for i in sys.argv:       #sys.argv 是一个包含命令行参数的列表。
   print(i)
 
print('\n\nPython 路径为:', sys.path, '\n')   #sys.path 包含了一个 Python 解释器自动查找所需模块的路径的列表

$ python using_sys.py 参数1 参数2
命令行参数如下:
using_sys.py
参数1
参数2


Python 路径为: ['/root', '/usr/lib/python3.4', '/usr/lib/python3.4/plat-x86_64-linux-gnu', '/usr/lib/python3.4/lib-dynload', '/usr/local/lib/python3.4/dist-packages', '/usr/lib/python3/dist-packages'] 

使用import语句的时候,Python解释器是怎样找到对应的文件的呢?涉及到Python的搜索路径,搜索路径是由一系列目录名组成的,Python解释器就依次从这些目录中去寻找所引入的模块,搜索路径是在Python编译或安装的时候确定的,安装新的库应该也会修改。搜索路径被存储在sys模块中的path变量

>>> import sys
>>> sys.path
['', '/usr/lib/python3.4', '/usr/lib/python3.4/plat-x86_64-linux-gnu', '/usr/lib/python3.4/lib-dynload', '/usr/local/lib/python3.4/dist-packages', '/usr/lib/python3/dist-packages']
>>> 

导入模块,利用(.)方法访问(调用)模块中的函数,经常使用一个函数,你可以把它赋给一个本地的名称。

>>> import fibo
>>> fib = fibo.fib   #赋给一个本地的名称
>>> fib(500)
1 1 2 3 5 8 13 21 34 55 89 144 233 377


fromimport 语句

>>> from fibo import fib, fib2     #导入模块 fibo 的 fib 函数
>>> fib(500)
1 1 2 3 5 8 13 21 34 55 89 144 233 377

fromimport * 语句.
把一个模块的所有内容全都导入到当前的命名空间

__name__属性

模块除了方法定义,还可以包括可执行的代码,这些代码一般用来初始化这个模块。这些代码只有在第一次被导入时才会被执行。

一个模块被另一个程序第一次引入时,其主程序将运行。如果想在模块被引入时,模块中的某一程序块不执行,可以用__name__属性来使该程序块仅在该模块自身运行时执行

每个模块都有一个__name__属性,当其值是’main’时,表明该模块自身在运行,否则是被引入。

说明:namemain 底下是双下划线, _ _ 是这样去掉中间的那个空格。

# Filename: using_name.py

if __name__ == '__main__':
   print('程序自身在运行')
else:
   print('我来自另一模块')

内置的函数 dir() 可以找到模块内定义的所有名称。以一个字符串列表的形式返回。

标准模块
有些模块直接被构建在解析器里,有一个特别的模块 sys ,它内置在每一个 Python 解析器中。


包是一种管理 Python 模块命名空间的形式,采用"点模块名称"。如一个模块的名称是 A.B, 那么他表示一个包 A中的子模块 B 。
目录只有包含一个叫做 init.py 的文件才会被认作是一个包。

sound/                          顶层包
      __init__.py               初始化 sound 包
      formats/                  文件格式转换子包
              __init__.py
              wavread.py
              wavwrite.py
              aiffread.py
              aiffwrite.py
              auread.py
              auwrite.py
              ...
      effects/                  声音效果子包
              __init__.py
              echo.py
              surround.py
              reverse.py
              ...
      filters/                  filters 子包
              __init__.py
              equalizer.py
              vocoder.py
              karaoke.py

每次只导入一个包里面的特定模块
 import sound.effects.echo

还有一种导入子模块的方法
from sound.effects import echo

直接导入一个函数或者变量:
from sound.effects.echo import echofilter
           

使用from Package import specific_submodule这种方法永远不会有错。事实上,这也是推荐的方法。

输入和输出

>>> for x in range(1, 11):
...     print(repr(x).rjust(2), repr(x*x).rjust(3), end=' ')
...     # 注意前一行 'end' 的使用
# rjust() 方法, 它可以将字符串靠右, 并在左边填充空格
...     print(repr(x*x*x).rjust(4))
...
 1   1    1
 2   4    8
 3   9   27
 4  16   64
 5  25  125
 6  36  216
 7  49  343
 8  64  512
 9  81  729
10 100 1000

>>> for x in range(1, 11):
...     print('{0:2d} {1:3d} {2:4d}'.format(x, x*x, x*x*x))
...

#方法 zfill(), 它会在数字的左边填充 0,
>>> '12'.zfill(5)
'00012'
>>> '-3.14'.zfill(7)
'-003.14'

str.format() 的基本使用


>>> print('{}55: "{}!"'.format('66', '000'))
6655"000"

>>> print('{0} 和 {1}'.format('Google', 'Runoob'))
Google 和 Runoob
>>> print('{1} 和 {0}'.format('Google', 'Runoob'))
Runoob 和 Google

使用了关键字参数
>>> print('{name}55: "{site}!"'.format(name='66', site='000'))
6655"000"

位置及关键字参数可以任意的结合:
>>> print('站点列表 {0}, {1}, 和 {other}。'.format('Google', 'Runoob', other='Taobao'))
站点列表 Google, Runoob, 和 Taobao。

在 table 变量前使用 ** 来实现传入一个字典
>>> table = {'Google': 1, 'Runoob': 2, 'Taobao': 3}
>>> print('Runoob: {Runoob:d}; Google: {Google:d}; Taobao: {Taobao:d}'.format(**table))
Runoob: 2; Google: 1; Taobao: 3

% 操作符也可以实现字符串格式化
>>> import math
>>> print('常量 PI 的值近似为:%5.3f。' % math.pi)
常量 PI 的值近似为:3.142。

读取键盘输入
str = input("请输入:");
print ("你输入的内容是: ", str)

读和写文件
open(filename, mode)     #open() 将会返回一个 file 对象

# 打开一个文件
f = open("/tmp/foo.txt", "w")

f.write( "Python 是一个非常好的语言。\n是的,的确非常好!!\n" )

# 关闭打开的文件
f.close()

文件对象的方法

f.read()
# 打开一个文件
f = open("/tmp/foo.txt", "r")

str = f.read()
print(str)

# 关闭打开的文件
f.close()

f.readline()
# 打开一个文件
f = open("/tmp/foo.txt", "r")

str = f.readline()
print(str)

# 关闭打开的文件
f.close()

str = f.readlines()  #返回该文件中包含的所有行
print(str)

for line in f:      #迭代一个文件对象然后读取每行
    print(line, end='')

num = f.write( "Python 是一个非常好的语言。\n是的,的确非常好!!\n" )  #将 string 写入到文件中, 然后返回写入的字符数
print(num)

#写入一些不是字符串的东西, 需要先进行转换
value = ('www.runoob.com', 14)  
s = str(value)
f.write(s)

f.tell() #返回文件对象当前所处的位置, 它是从文件开头开始算起的字节数

f.seek()   #如果要改变文件当前的位置,

seek(x,0) #从起始位置即文件首行首字符开始移动 x 个字符,默认模式。
seek(x,1) #表示从当前位置往后移动x个字符
seek(-x,2)#表示从文件的结尾往前移动x个字符

#使用 with 关键字处理一个文件对象,结束后帮你正确的关闭文件
>>> with open('/tmp/foo.txt', 'r') as f:
...     read_data = f.read()
>>> f.closed
True

pickle 模块

实现了基本的数据序列和反序列化
通过pickle模块的序列化操作,能够将程序中运行的对象信息保存到文件中去,永久存储。

通过pickle模块的反序列化操作,能够从文件中创建上一次程序保存的对象。

pickle.dump(obj, file, [,protocol])     #

x = pickle.load(file)   #从 file 中读取一个字符串,并将它重构为原来的python对象

import pickle
# 使用pickle模块将数据对象保存到文件
data1 = {'a': [1, 2.0, 3, 4+6j],
         'b': ('string', u'Unicode string'),
         'c': None}

selfref_list = [1, 2, 3]
selfref_list.append(selfref_list)

output = open('data.pkl', 'wb')

# Pickle dictionary using protocol 0.
pickle.dump(data1, output)

# Pickle the list using the highest protocol available.
pickle.dump(selfref_list, output, -1)

output.close()

import pprint, pickle
#使用pickle模块从文件中重构python对象
pkl_file = open('data.pkl', 'rb')

data1 = pickle.load(pkl_file)
pprint.pprint(data1)

data2 = pickle.load(pkl_file)
pprint.pprint(data2)

pkl_file.close()

File(文件) 方法

#接收两个参数:文件名(file)和模式(mode),一定要保证关闭文件对象
open(file, mode='r')

open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)

file: 必需,文件路径(相对或者绝对路径)。
mode: 可选,文件打开模式
buffering: 设置缓冲
encoding: 一般使用utf8
errors: 报错级别
newline: 区分换行符
closefd: 传入的file参数类型
opener:

mode 参数:t(文本模式,默认)、x(写模式)、a(追加)

file 对象
file.close()
file.flush()  #刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件
file.fileno()#返回一个整型的文件描述符(file descriptor FD 整型)
file.isatty()#如果文件连接到一个终端设备返回 True,否则返回 False	
file.read([size])#从文件读取指定的字节数,如果未给定或为负则读取所有
file.readline([size])  #读取整行,包括 "\n" 字符
file.readlines([sizeint]) #读取所有行并返回列表,若给定sizeint>0,返回总和大约为sizeint字节的行, 实际读取值可能比 sizeint 较大, 因为需要填充缓冲区
file.seek(offset[, whence]) #设置文件当前位置	
file.tell()#返回文件当前位置
file.truncate([size])#从文件的首行首字符开始截断,截断文件为 size 个字符,无 size 表示从当前位置截断;截断之后后面的所有字符被删除,其中 Widnows 系统下的换行代表2个字符大小
file.write(str)  #将字符串写入文件,返回的是写入的字符长度
file.writelines(sequence)  #向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值