⑥python模块初识、pyc和PyCodeObject

一、模块初识(一)

模块,也叫库。库有标准库第三方库。

注意事项:文件名不能和导入的模块名相同

1. sys模块

import sys
print(sys.path) #打印环境变量
print(sys.argv) #打印相对路径,在pycharm输出结果是绝对路径,因为在pycharm中调用

标准库存放位置:C:\Python35\Lib

第三方库存放位置C:\Python35\Lib\site-packages

2. OS模块

    实例一:

import os
os.system("dir")
print(cmd_res)

  实例二:

import os
cmd_res = os.system("dir") #执行命令,不保存结果
print("--->",cmd_res)

输出结果为0(因为调用os模块的输出结果只到屏幕,0是命令执行的成功与否的状态码返回0为成功)返回0为成功

    实例三:

import os 
cmd_res = os.popen("dir").read()
print("--->",cmd_res)

注意加“.read()”和不加的区别:不加输出结果是内存地址,加了指用read()来读取

    实例四:在当前目录下创建目录

import os
os.mkdir("new_dir")
print("--->",cmd_res)

3.导入模块

当Python内置的核心模块提供的功能无法满足我们的需求时就需要导入外部模块,而导入模块的功能有两种方式:

  • import MODULE :导入整个模块
  • from MODULE import XX :导入模块中的一部分(方法、变量、或常量等)

例如,要想查看或更改python查找模块的路径列表就需要使用sys模块下的path变量;若需要执行系统命令可以使用os模块下的system()方法。

import sys
from os import system

print(sys.path)
print(system("ping www.baidu.com"))
C:\Users\peng>python3
Python 3.5.2 (v3.5.2:4def2a2901a5, Jun 25 2016, 22:18:55) [MSC v.1900 64 bit (AM
D64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> import sys
>>> from os import system
>>>
>>> print(sys.path)
['', 'C:\\Python35\\python35.zip', 'C:\\Python35\\DLLs', 'C:\\Python35\\lib', 'C
:\\Python35', 'C:\\Python35\\lib\\site-packages']
>>> print(system("ping www.baidu.com"))

正在 Ping www.baidu.com [14.215.177.37] 具有 32 字节的数据:
来自 14.215.177.37 的回复: 字节=32 时间=9ms TTL=55
来自 14.215.177.37 的回复: 字节=32 时间=7ms TTL=55
来自 14.215.177.37 的回复: 字节=32 时间=6ms TTL=55
来自 14.215.177.37 的回复: 字节=32 时间=6ms TTL=55

14.215.177.37 的 Ping 统计信息:
    数据包: 已发送 = 4,已接收 = 4,丢失 = 0 (0% 丢失),
往返行程的估计时间(以毫秒为单位):
    最短 = 6ms,最长 = 9ms,平均 = 7ms
0
>>>

 

二、.pyc是什么

1. python是一门解释型语言?

    初学python时,听到的关于python的第一句话就是,python是一门解释型语言,直到发现了*.pyc文件的存在。如果是解释型语言,那么生成的*.pyc文件时什么呢?

    c应该是compiled的缩写。

    为了防止学习python时被这句话误解,需要澄清这个问题,并且把一些基础概念给理清。

2. 解释型语言和编译型语言

    计算机是不能识别高级语言的,所以当我们运行一个高级语言程序的时候就需要一个“翻译机”来从事把高级语言转变成计算机能读懂的机器语言的过程。这个过程分成两类,第一种是编译,第二种是解释。

    编译型语言在程序执行之前,先会通过编译器对程序执行一个编译的过程,把程序转变成机器语言。运行时就不需要翻译,而直接执行就可以了。最典型的例子就是C语言。

    解释型语言就没有这个编译的过程,而是程序运行的时候,通过解释器对程序逐行做出解释,然后直接运行,最典型的例子就是Ruby。 

    通过以上的例子,总结一下解释型语言和编译型语言的优缺点。因为编译型语言在程序运行之前就已经对程序做出了“翻译”,所以在运行时就烧掉了“翻译”的过程,所以效率比较 高。但是我们也不能一概而论,一些解释型语言也可以通过解释器的优化来在对程序做出翻译时对整个程序做出优化,从而在效率上接近编译型语言。

    此外,随着Java等基于虚拟机的语言的兴起,我们有不能把语言纯粹地分成解释型和编译型这两种。

    用Java来举例,java首先是通过编译器编译成字节码文件,然后在运行时通过解释器给解释成机器文件。所以说java是一种先编码后解释的语言。

3. python到底是什么 

    其实python和java/C#一样,也是一门基于虚拟机的语言。
    当我们在命令行中输入python hello.py时,其实是激活了python的“解释器”,告诉“解释器”:你要开始工作了。

    可是在“解释”之前,其实执行的第一项工作和java一样,是编译。

    python是一门先编译后解释的语言。

4. 简述python的运行过程   

    在说这个问题之前,先说两个概念,PyCodeObject和pyc文件。
    其实PyCodeObject则是python编译器真正编译成的结果

    当python程序运行时,编译的结果则是保存在位于内存中的PyCodeObject中,当python程序运行结束时,python解释器则将PyCodeObject写回到pyc文件中。

    当python程序第二次运行时,首先程序会在硬盘中寻找pyc文件,如果找到,则直接载入,否则就重复上面的过程。

    所以我们应该这样来定位PyCodeObject和pyc文件,我们说pyc文件其实是PyCodeObject的一种持久化保存方式。

posted @ 2017-03-22 13:06  penghx  阅读(292)  评论(0编辑  收藏  举报