study note4
模块初识:调用模块的时候先从当前目录下找,再从全局系统变量里找
全局系统变量地址:C:\\Users\\Deakin\\PycharmProjects\\untitled2\\venv\\lib\\site-packages 或者print(sys.path)来查看,自己写的模块不放在这2个地方无法调用。
sys:
import sys
print(sys.path) #打印环境变量
print(sys.argv) #打印此脚本的路径(在pycharm里是绝对路径,在终端里是相对路径)
------------------------------------------------------------------------------------------------------------
os:调用系统模块
import os
cmd_res=os.system("dir")#执行命令不保存结果
print("--->",cmd_res) #命令cmd_res执行是直接输出到屏幕上,所以打印的时候并不会打印出来,返回的0代表命令执行成功了
打印结果:
C:\Users\Deakin\PycharmProjects\untitled2\venv\Scripts\python.exe C:/Users/Deakin/PycharmProjects/untitled2/12.29/os.py
������ C �еľ�û�б�ǩ��
�������� 5CAE-302C
C:\Users\Deakin\PycharmProjects\untitled2\12.29 ��Ŀ¼
2017/12/29 14:55 <DIR> .
2017/12/29 14:55 <DIR> ..
2017/12/29 14:55 183 os.py
2017/12/29 14:50 185 sys.py
2 ���ļ� 368 �ֽ�
2 ��Ŀ¼ 161,618,034,688 �����ֽ�
---> 0
-------------------------------------------------------------------------------------------------------------------
如果想打印出来:
import os
cmd_res=os.popen("dir").read()
print("--->",cmd_res)
打印结果:
C:\Users\Deakin\PycharmProjects\untitled2\venv\Scripts\python.exe "C:/Users/Deakin/PycharmProjects/untitled2/12.29/os open.py"
---> 驱动器 C 中的卷没有标签。
卷的序列号是 5CAE-302C
C:\Users\Deakin\PycharmProjects\untitled2\12.29 的目录
2017/12/29 15:38 <DIR> .
2017/12/29 15:38 <DIR> ..
2017/12/29 15:38 185 os open.py
2017/12/29 15:00 346 os.py
2017/12/29 14:50 185 sys.py
3 个文件 716 字节
2 个目录 161,651,625,984 可用字节
------------------------------------------------------------------------------------------
.pyc是个什么鬼?
1. Python是一门解释型语言?
我初学Python时,听到的关于Python的第一句话就是,Python是一门解释性语言,我就这样一直相信下去,直到发现了*.pyc文件的存在。如果是解释型语言,那么生成的*.pyc文件是什么呢?c应该是compiled的缩写才对啊!
为了防止其他学习Python的人也被这句话误解,那么我们就在文中来澄清下这个问题,并且把一些基础概念给理清。
2. 解释型语言和编译型语言
计算机是不能够识别高级语言的,所以当我们运行一个高级语言程序的时候,就需要一个“翻译机”来从事把高级语言转变成计算机能读懂的机器语言的过程。这个过程分成两类,第一种是编译,第二种是解释。
编译型语言在程序执行之前,先会通过编译器对程序执行一个编译的过程,把程序转变成机器语言。运行时就不需要翻译,而直接执行就可以了。最典型的例子就是C语言。
解释型语言就没有这个编译的过程,而是在程序运行的时候,通过解释器对程序逐行作出解释,然后直接运行,最典型的例子是Ruby。
通过以上的例子,我们可以来总结一下解释型语言和编译型语言的优缺点,因为编译型语言在程序运行之前就已经对程序做出了“翻译”,所以在运行时就少掉了“翻译”的过程,所以效率比较高。但是我们也不能一概而论,一些解释型语言也可以通过解释器的优化来在对程序做出翻译时对整个程序做出优化,从而在效率上超过编译型语言。
此外,随着Java等基于虚拟机的语言的兴起,我们又不能把语言纯粹地分成解释型和编译型这两种。
用Java来举例,Java首先是通过编译器编译成字节码文件,然后在运行时通过解释器给解释成机器文件。所以我们说Java是一种先编译后解释的语言。
3. Python到底是什么
其实Python和Java/C#一样,也是一门基于虚拟机的语言,我们先来从表面上简单地了解一下Python程序的运行过程吧。
当我们在命令行中输入python hello.py时,其实是激活了Python的“解释器”,告诉“解释器”:你要开始工作了。可是在“解释”之前,其实执行的第一项工作和Java一样,是编译。
熟悉Java的同学可以想一下我们在命令行中如何执行一个Java的程序:
javac hello.java
java hello
只是我们在用Eclipse之类的IDE时,将这两部给融合成了一部而已。其实Python也一样,当我们执行python hello.py时,他也一样执行了这么一个过程,所以我们应该这样来描述Python,Python是一门先编译后解释的语言。
4. 简述Python的运行过程
在说这个问题之前,我们先来说两个概念,PyCodeObject和pyc文件。
我们在硬盘上看到的pyc自然不必多说,而其实PyCodeObject则是Python编译器真正编译成的结果。我们先简单知道就可以了,继续向下看。
当python程序运行时,编译的结果则是保存在位于内存中的PyCodeObject中,当Python程序运行结束时,Python解释器则将PyCodeObject写回到pyc文件中。
当python程序第二次运行时,首先程序会在硬盘中寻找pyc文件,如果找到,则直接载入,否则就重复上面的过程。
所以我们应该这样来定位PyCodeObject和pyc文件,我们说pyc文件其实是PyCodeObject的一种持久化保存方式
PS:如果更改了源代码,那么python会先检测源代码和pyc文件的日期,如果代码的日期更新,则会重新编译生成新的pyc文件。
2 是一个整数的例子。
长整数 不过是大一些的整数。
3.23和52.3E-4是浮点数的例子。E标记表示10的幂。在这里,52.3E-4表示52.3 * 10-4。
(-5+4j)和(2.3-4.6j)是复数的例子,其中-5,4为实数,j为虚数,数学中表示复数是什么?。PS:没卵用,忘记它。
int(整型)
在64位系统上,整数的位数为64位,取值范围为-2**63~2**63-1,即-9223372036854775808~9223372036854775807
跟C语言不同,Python的长整数没有指定位宽,即:Python没有限制长整数数值的大小,但实际上由于机器内存有限,我们使用的长整数数值不可能无限大。
注意,自从Python2.2起,如果整数发生溢出,Python会自动将整数数据转换为长整数,所以如今在长整数数据后面不加字母L也不会导致严重后果了。
float(浮点型)
浮点数用来处理实数,即带有小数的数字。类似于C语言中的double类型,占8个字节(64位),其中52位表示底,11位表示指数,剩下的一位表示符号。
complex(复数)
复数由实数部分和虚数部分组成,一般形式为x+yj,其中的x是复数的实数部分,y是复数的虚数部分,这里的x和y都是实数。
"hello world"
1
2
3
4
|
name = "alex" print "i am %s " % name #输出: i am alex |
PS: 字符串是 %s;整数 %d;浮点数%f
- 移除空白
- 分割
- 长度
- 索引
- 切片