首页 > 自动化运维 > python > 菜鸟篇4–用户输入和初始模块
2016
11-26

菜鸟篇4–用户输入和初始模块

一  用户输入

#!/usr/bin/env python3
# -*- coding:utf-8 -*-
# Author:woodman
#例 1
#user_input = raw_input("input your name: ")
name = input("input your name:")
age = int(input("input your age:"))  ##conver str to int
job = input("input your job:")
print(name,age,job)

输出的结果很丑,如果你拿这样的程序去面试,那么通常都是回家等消息,然后就没有然后了。

例 2

name = input("input your name:")
age = int(input("input your age:"))  ##conver str to int
job = input("input your job:")
msg ='''
Infomation of user %s:
----------------------
Name:   %s
Age :   %d
Job :   %s
---------END----------
'''%(name,name,age,job)
print(msg)

这样看起来就要舒服多了,拿着它你就可以进公司扫地了。

二 模块初始

Python的强大之处在于他有非常丰富和强大的标准库和第三方库,几乎你想实现的任何功能都有相应的Python库支持。


调用os模块,可以执行shell,看到这些命令会不会觉得很亲切。

如果你说不会shell,不好意思回去自学吧。

下面为了将“df -h”的输出保存下来,先用了read读,然后使用popen这个类存储下来。

import os
os.system('df -h')
os.mkdir('mydocument')
cms_res = os.popen("df -h ").read()
import getpass
username = input("username:")
password = getpass.getpass("password:")
print(username,password)


自己写个tab补全模块,下面是linux的补全模块(mac的自己百度去),win下木有。。。

#!/usr/bin/env python3
# python startup file
import sys
import readline
import rlcompleter
import atexit
import os
# tab completion
readline.parse_and_bind('tab: complete')
# history file
histfile = os.path.join(os.environ['HOME'], '.pythonhistory')
try:
readline.read_history_file(histfile)
except IOError:
pass
atexit.register(readline.write_history_file, histfile)
del os, histfile, readline, rlcompleter

#将上面写好的tab.py放在下面的目录,然后就可以在任意地方进入python且能调用tab模块了。


import sys

print(sys.path)  

#C:\\Python35\\lib\\site-packages

#/usr/local/lib/python2.7/dist-packages


三 .pyc是个什么鬼?

下面的内容是从一个大神处copy而来,请认真拜读。

作为菜鸟的我,看来三遍。。。。

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的一种持久化保存方式。

----------------------------------------------


最后编辑:
作者:wood-man
这个作者貌似有点懒,什么都没有留下。
捐 赠您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请狠狠点击

留下一个回复