标签:return 脚本 view 统一 机器 with python版本 sleep 版本
Python可以应用于众多领域,如:数据分析、组件集成、网络服务、图像处理、数值计算和科学计算等众多领域。目前业内几乎所有大中型互联网企业都在使用Python,如:Youtube、Dropbox、BT、Quora(中国知乎)、豆瓣、知乎、Google、Yahoo!、Facebook、NASA、百度、腾讯、汽车之家、美团等。
互联网公司广泛使用Python来做的事一般有:自动化运维、自动化测试、大数据分析、爬虫、Web 等。
Python与其他语言
C和Python、java、C#
C:代码编译得到机器码,机器码在处理器上直接执行,每一条命令交给CPU执行
其他语言: 代码编译得到 字节码 ,虚拟机执行字节码并转换成机器码再后在处理器上执行
Python 和 C Python这门语言是由C开发而来
对于使用:Python的类库齐全并且使用简洁,如果要实现同样的功能,Python 10行代码可以解决,C可能就需要100行甚至更多.
对于速度:Python的运行速度相较与C,绝逼是慢了
Python 和 Java、C#等
对于使用:Linux原装Python,其他语言没有;以上几门语言都有非常丰富的类库支持
对于速度:Python在速度上可能稍显逊色
所以,Python和其他语言没有什么本质区别,其他区别在于:擅长某领域、人才丰富、先入为主。
https:
/
/
www.python.org
/
downloads
/
更改环境变量:在高级系统设置更改环境变量,path后面加上python安装的路径 (不行就百度)
在cmd内输入python成功,则安装成功
linux下自带python环境,无需安装。如需要更新版本,那就再装一个新版本的,不用卸载
查看python版本: python -V
安装gcc,用于编译python源码: yum install gcc
下载源码安装包 : https://www.python.org/ftp/python/
解压并进入源码文件
编译安装: ./configure
make all
make install
修改默认python版本:
mv /usr/bin/python /usr/bin/python2.6
ln -s /usr/local/bin/python2.7 /usr/bin/python
防止yum执行异常,修改yum使用的python版本
vi /usr/bin/yum
将头部 #!/usr/bin/python 改为 #!/usr/bin/python2.6
执行代码
在/home/dev目录下创建hello.py文件
执行hello.py文件: python /home/dev/hello.py
python的解释器 程序入口指定
类似于shell的 #!/bin/bash
当执行到/home/dev/hello.py时,明确的指出hello.py脚本由python解释器来执行
如果想要类似于执行sheel脚本一样执行python程序,类似于./hello.py,那么就需要在hello.py文件的头部指定解释器
#!/usr/bin/env python
python解释器在加载.py文件中的代码时,会对内容进行编码(默认ASCII)
ASCII(美国标准信息交换码)是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其他西欧语言,其最多只能用8位来表示(一个字节),即2**8=256,所以最多256位
显然ASCII无法显示出世界上各种文字和符号,所以,就需要一种新的编码方式来代表所有的语言符号:Unicode
Unicode(统一码,万国码,单一码)是一种在计算机上使用的字符编码。Unicode是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,规定虽有得字符和符号最少由16位来表示(2个字节),即:2**16 = 65536, (最少2个字节,还可能最多)
UTF-8,是对Unicode编码的压缩和优化,他不再是最少使用2个字节,而是将所有的字符和符号进行分类:ASCII码中的内容用1个字节保存、欧洲的字符用2个字节保存、东亚的字符用3个字节保存。。。
所以,python解释器在加载.py程序时,是无法显示出中文的,所以就需要告诉解释器,应该用什么编码来执行源代码
# -*- coding: utf-8 -*-
当行注释: #注释内容
跨行注释: ‘‘‘ 注释内容 ‘‘‘
python有大量的模块,从而使得python程序非常简洁。类库有三大类:
python内部提供的模块
业内开源的模块
程序员自己开发的模块
python内部提供了一个sys的模块,其中sys.argv用来捕获执行执行python脚本时传入的参数
#!/usr/bin/env python # -*- coding: utf-8 -*- import sys print sys.argv
执行Python代码时,如果导入了其他的.py文件,那么,执行过程中会自动生成一个与其同名的.pyc文件,该文件就是Python解释器编译之后产生的字节码。
代码经过编译可以产生字节码;字节码通过反编译也可以得到代码。
变量声明:
name = "happy" #变量名为name,变量name的值为: "happy"
变量的作用:昵称,其代指内存里某个地址中的保存内容
变量定义的规则:
变量名只能是 字母、数字或下划线的任意组合
变量名是第一个字节不能是数字
以下关键字不能声明为变量名
[‘and‘, ‘as‘, ‘assert‘, ‘break‘, ‘class‘, ‘continue‘, ‘def‘, ‘del‘, ‘elif‘, ‘else‘, ‘except‘, ‘exec‘, ‘finally‘, ‘for‘, ‘from‘, ‘global‘, ‘if‘, ‘import‘, ‘in‘, ‘is‘, ‘lambda‘, ‘not‘, ‘or‘, ‘pass‘, ‘print‘, ‘raise‘, ‘return‘, ‘try‘, ‘while‘, ‘with‘, ‘yield‘]
变量的赋值:
name1 = "alex" name2 = name1 print(id(name1)) print(id(name2)) name1 = "alex" name2 = "alex" print(id(name1)) print(id(name2))
只要赋予的值值是相同的,内存id就是一样的,即保存的位置就是一样的
1 #!/usr/bin/env python 2 # -*- coding: utf-8 -*- 3 4 # 将用户输入的内容赋值给 name 变量 5 name = raw_input("请输入用户名:") 6 7 # 打印输入的内容 8 print name
输入代码时,如果想不可见,可以利用getpass模块中getpass方法:
#!/usr/bin/env python # -*- coding: utf-8 -*- import getpass # 将用户输入的内容赋值给 name 变量 pwd = getpass.getpass("请输入密码:") # 打印输入的内容 print pwd
python对缩进的要求非常严格,变态的严格。
用户登录验证:
1 #!/usr/bin/env python 2 # -*- coding: encoding -*- 3 4 # 提示输入用户名和密码 5 6 # 验证用户名和密码 7 # 如果错误,则输出用户名或密码错误 8 # 如果成功,则输出 欢迎,XXX! 9 10 11 import getpass 12 13 14 name = raw_input(‘请输入用户名:‘) 15 pwd = getpass.getpass(‘请输入密码:‘) 16 17 if name == "alex" and pwd == "cmd": 18 print "欢迎,alex!" 19 else: 20 print "用户名和密码错误"
1 #!/usr/bin/env python 2 # _*_ coding:utf-8 _*_ 3 __author__ = ‘Administrator‘ 4 5 name = input("\033[34;1mpls input ur username:\033[0m") 6 pwd = input("\033[34;1mpls input ur passwd:\033[0m") 7 if name == "alex" and pwd == "123": 8 print("\033[35;1myes\033[0m") 9 else: 10 print("\033[31;1mno\033[0m")
多层判断
1 #!/usr/bin/env python 2 # _*_ coding:utf-8 _*_ 3 __author__ = ‘Administrator‘ 4 5 inp = raw_input(">>>") 6 if inp == "1": 7 print(‘1‘) 8 elif inp == "2": 9 print(‘2‘) 10 else: 11 print("other")
根据用户输入内容给予权限:
# 根据用户输入内容打印其权限 # alex --> 超级管理员 # eric --> 普通管理员 # tony,rain --> 业务主管 # 其他 --> 普通用户 name = raw_input(‘请输入用户名:‘) if name == "alex": print "超级管理员" elif name == "eric": print "普通管理员" elif name == "tony" or name == "rain": print "业务主管" else: print "普通用户"
基本循环:
while循环条件:
循环体
如果条件为真,那么循环体则被执行
如果条件为假,那么循环体不执行
break:
break用于退出所有循环
while True: print "123" break print "456"
continue:
continue用于退出当前循环,继续下一次循环
while True: print "123" continue print "456"
1、使用
while
循环输入 1 2 3 4 5 6 8 9 10
1 #!/usr/bin/env python 2 # _*_ coding:utf-8 _*_ 3 __author__ = ‘Administrator‘ 4 5 i=0 6 while i<=10: 7 time.sleep(0.1) 8 i+=1 9 if i == 7: 10 continue 11 print i 12 print("end")
2、求1-100的所有数的和
1 #!/usr/bin/env python 2 # _*_ coding:utf-8 _*_ 3 __author__ = ‘Administrator‘ 4 5 #1到100求和 6 7 j=0 8 i=1 9 while i<=100: 10 j+=i 11 i+=1 12 print j
3、输出 1-100 内的所有奇数
1 #!/usr/bin/env python 2 # _*_ coding:utf-8 _*_ 3 __author__ = ‘Administrator‘ 4 5 # 奇数 求和 6 j=0 7 i=1 8 while i<=100: 9 j+=i 10 i+=2 11 print j
4、输出 1-100 内的所有偶数
1 #!/usr/bin/env python 2 # _*_ coding:utf-8 _*_ 3 __author__ = ‘Administrator‘ 4 #偶数 求和 5 j=0 6 i=0 7 while i<=100: 8 j+=i 9 i+=2 10 print j
5、求1-2+3-4+5 ... 99的所有数的和
1 #!/usr/bin/env python 2 # _*_ coding:utf-8 _*_ 3 __author__ = ‘Administrator‘ 4 5 # 奇数 求和 6 j=0 7 i=1 8 while i<=100: 9 j+=i 10 i+=2 11 print j 12 13 #偶数 求和 14 k=0 15 l=0 16 while l<=100: 17 k+=l 18 l+=2 19 print k 20 21 print(j-k)
6、用户登陆(三次机会重试)
1 #!/user/bin/env python 2 # -*- coding:utf-8 -*- 3 import getpass 4 5 count = 1 6 true_name = "alex" 7 true_passwd = "123" 8 while count <= 3 : 9 count = count + 1 10 name = raw_input("please input your username:").strip() 11 if len(name) == 0: 12 continue 13 else: 14 passwd = raw_input("please input your password:").strip() 15 if name == true_name and passwd == true_passwd: 16 print ("hello alex!") 17 #count = 4 18 break 19 elif count <= 3 and (name <> true_name or passwd <> true_passwd) : 20 print ("your username or password is wrong,please input again") 21 else: 22 print ("傻逼滚!")
标签:return 脚本 view 统一 机器 with python版本 sleep 版本
原文地址:http://www.cnblogs.com/carzynonsense/p/6337877.html