#!/usr/bin/python3
 print('Python十')#101、Python3模块
 import sys
 print('命令行参数如下')
 for x in sys.argv:
     print(x)
 print('\n\nPython 路径为:', sys.path, '\n')# 102、斐波那契(fibonacci)数列模块
 def fib(n):    # 定义到 n 的斐波那契数列
     a, b = 0, 1
     while b < n:
         print(b, end=' ')
         a, b = b, a+b
     print()
  
 def fib2(n): # 返回到 n 的斐波那契数列
     result = []
     a, b = 0, 1
     while b < n:
         result.append(b)
         a, b = b, a+b
     return result
 # __name__属性
 # 一个模块被另一个程序第一次引入时,其主程序将运行。如果我们想在模块被引入时,模块中的某一程序块不执行,我们可以用__name__属性来使该程序块仅在该模块自身运行时执行。
 # 每个模块都有一个__name__属性,当其值是'__main__'时,表明该模块自身在运行,否则是被引入。
 if __name__ == '__main__':
    print('程序自身在运行')
 else:
    print('我来自另一模块')#103、dir() 函数
 # 内置的函数 dir() 可以找到模块内定义的所有名称。以一个字符串列表的形式返回:
 import sys
 print('sys:\n',dir(sys))#104读取键盘输入
 '''
 # Python提供了 input() 内置函数从标准输入读入一行文本,默认的标准输入是键盘。
 # input 可以接收一个Python表达式作为输入,并将运算结果返回。
 str = input("请输入:");
 print ("你输入的内容是: ", str)
 '''#105、读和写文件
 '''
 open() 将会返回一个 file 对象,基本语法格式:
 open(filename, mode)
 filename:包含了你要访问的文件名称的字符串值。
 mode:决定了打开文件的模式:只读,写入,追加等。所有可取值见如下的完全列表。这个参数是非强制的,默认文件访问模式为只读(r)。
 不同模式打开文件的完全列表:
 模式    描述
 r    以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
 rb    以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。
 r+    打开一个文件用于读写。文件指针将会放在文件的开头。
 rb+    以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
 w    打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
 wb    以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
 w+    打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
 wb+    以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
 a    打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
 ab    以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
 a+    打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
 ab+    以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。
 '''
 # 打开一个文件
 f = open("/tmp/foo.txt", "w")
 f.write( "Python 是一个非常好的语言。\n是的,的确非常好!!\n" )
 # 关闭打开的文件
 f.close()# 106、文件对象的方法
 # f.read()
 '''
 为了读取一个文件的内容,调用 f.read(size), 这将读取一定数目的数据, 然后作为字符串或字节对象返回。
 size 是一个可选的数字类型的参数。 当 size 被忽略了或者为负, 那么该文件的所有内容都将被读取并且返回。
 以下实例假定文件 foo.txt 已存在(上面实例中已创建):
 '''
 # 打开一个文件
 f = open("/tmp/foo.txt", "r")
 str = f.read()
 print(str)
 # 关闭打开的文件
 f.close()# f.readline()
 # f.readline() 会从文件中读取单独的一行。换行符为 '\n'。f.readline() 如果返回一个空字符串, 说明已经已经读取到最后一行。
 # 打开一个文件
 f = open("/tmp/foo.txt", "r")
 str = f.readline()
 print(str)
 # 关闭打开的文件
 f.close()# f.readlines()
 # f.readlines() 将返回该文件中包含的所有行。
 # 如果设置可选参数 sizehint, 则读取指定长度的字节, 并且将这些字节按行分割。
 # 打开一个文件
 f = open("/tmp/foo.txt", "r")
 str = f.readlines()
 print(str)
 # 关闭打开的文件
 f.close()
 # 迭代一个文件对象然后读取每行:
 # 打开一个文件
 f = open("/tmp/foo.txt", "r")
 for line in f:
     print(line, end='')
 # 关闭打开的文件
 f.close()# f.write()
 # f.write(string) 将 string 写入到文件中, 然后返回写入的字符数。
 # 打开一个文件
 f = open("/tmp/foo.txt", "w")
 num = f.write( "Python 是非常好的语言。是的,的确非常好!!\n" )
 print(num)
 # 关闭打开的文件
 f.close()# 107、
 '''
 f.tell()
 f.tell() 返回文件对象当前所处的位置, 它是从文件开头开始算起的字节数。
 f.seek()
 如果要改变文件当前的位置, 可以使用 f.seek(offset, from_what) 函数。
 from_what 的值, 如果是 0 表示开头, 如果是 1 表示当前位置, 2 表示文件的结尾,例如:
 seek(x,0) : 从起始位置即文件首行首字符开始移动 x 个字符
 seek(x,1) : 表示从当前位置往后移动x个字符
 seek(-x,2):表示从文件的结尾往前移动x个字符
 from_what 值为默认为0,即文件开头。
 下面给出一个实例:
 >>> f = open('/tmp/foo.txt', 'rb+')
 >>> f.write(b'0123456789abcdef')
 16
 >>> f.seek(5)     # 移动到文件的第六个字节
 5
 >>> f.read(1)
 b'5'
 >>> f.seek(-3, 2) # 移动到文件的倒数第三字节
 13
 >>> f.read(1)
 b'd'
 '''#108、f.close()
 '''
 在文本文件中 (那些打开文件的模式下没有 b 的), 只会相对于文件起始位置进行定位。
 当你处理完一个文件后, 调用 f.close() 来关闭文件并释放系统的资源,如果尝试再调用该文件,则会抛出异常。
 >>> f.close()
 >>> f.read()
 Traceback (most recent call last):
   File "<stdin>", line 1, in ?
 ValueError: I/O operation on closed file
 当处理一个文件对象时, 使用 with 关键字是非常好的方式。在结束后, 它会帮你正确的关闭文件。 而且写起来也比 try - finally 语句块要简短:
 >>> with open('/tmp/foo.txt', 'r') as f:
 ...     read_data = f.read()
 >>> f.closed
 True
 '''# 109、pickle 模块
 '''
 python的pickle模块实现了基本的数据序列和反序列化。
 通过pickle模块的序列化操作我们能够将程序中运行的对象信息保存到文件中去,永久存储。
 通过pickle模块的反序列化操作,我们能够从文件中创建上一次程序保存的对象。
 基本接口:
 pickle.dump(obj, file, [,protocol])
 有了 pickle 这个对象, 就能对 file 以读取的形式打开:
 x = pickle.load(file)
 从 file 中读取一个字符串,并将它重构为原来的python对象。
 file: 类文件对象,有read()和readline()接口。
 '''
 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() #110
 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()