全栈Python教程day1


 
Python在一些公司的应用: 
  • 谷歌:Google App Engine 、code.google.com 、Google earth 、谷歌爬虫、Google广告等项目都在大量使用Python开发
  • CIA: 美国中情局网站就是用Python开发的
  • NASA: 美国航天局(NASA)大量使用Python进行数据分析和运算
  • YouTube:世界上最大的视频网站YouTube就是用Python开发的
  • Dropbox:美国最大的在线云存储网站,所有用Python实现,天天网站处理10亿个文件的上传和下载
  • Instagram:美国最大的图片分享社交网站,天天超过3千万张照片被分享,所有用python开发
  • Facebook:大量的基础库均经过Python实现的
  • Redhat: 世界上最流行的Linux发行版本中的yum包管理工具就是用python开发的
  • 豆瓣: 公司几乎全部的业务均是经过Python开发的
  • 知乎: 国内最大的问答社区,经过Python开发(国外Quora)
  • 春雨医生:国内知名的在线医疗网站是用Python开发的
  • 除上面以外,还有搜狐、金山、腾讯、盛大、网易、百度、阿里、淘宝 、土豆、新浪、果壳等公司都在使用Python完成各类各样的任务。
  • 1989年,为了打发圣诞节假期,Guido开始写Python语言的编译器。Python这个名字,来自Guido所挚爱的电视剧Monty Python’s Flying Circus。他但愿这个新的叫作Python的语言,能符合他的理想:创造一种C和shell之间,功能全面,易学易用,可拓展的语言。
  • 1991年,第一个Python编译器诞生。它是用C语言实现的,并可以调用C语言的库文件。从一出生,Python已经具备了:类,函数,异常处理,包含表和词典在内的核心数据类型,以及模块为基础的拓展系统。
  • Granddaddy of Python web frameworks, Zope 1 was released in 1999
  • Python 2.0 - October 16, 2000,加入了内存回收机制,构成了如今Python语言框架的基础
  • Python 2.4 - November 30, 2004, 同年目前最流行的WEB框架Django 诞生
  • Python 2.5 - September 19, 2006
  • Python 2.6 - October 1, 2008
  • Python 2.7 - July 3, 2010
  • In November 2014, it was announced that Python 2.7 would be supported until 2020, and reaffirmed that there would be no 2.8 release as users were expected to move to Python 3.4+ as soon as possible
  • Python 3.0 - December 3, 2008
  • Python 3.1 - June 27, 2009
  • Python 3.2 - February 20, 2011
  • Python 3.3 - September 29, 2012
  • Python 3.4 - March 16, 2014
  • Python 3.5 - September 13, 2015
windows
linux、Mac
  在linux 下建立一个文件叫hello.py,并输入
而后执行命令:python hello.py ,输出
指定解释器
上一步中执行 python hello.py 时,明确的指出 hello.py 脚本由 python 解释器来执行。
若是想要相似于执行shell脚本同样执行python脚本,例:  ./hello.py  ,那么就须要在 hello.py 文件的头部指定解释器,以下:
如此一来,执行: . /hello.py  便可。
ps:执行前需给予 hello.py 执行权限,chmod 755 hello.py
在交互器中执行 
除了把程序写在文件里,还能够直接调用python自带的交互器运行代码, 
name = "lv"
name2 = name
print ( "My name is " , name ,name2)
name = "shihai"
print ( "My name is " , name ,name2)

python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill)
ASCII(American Standard Code for Information Interchange,美国标准信息交换代码)是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其余西欧语言,其最多只能用 8 位来表示(一个字节),即:2**8 = 256-1,因此,ASCII码最多只能表示 255 个符号。
 
  
 
 
 
1、Python介绍
python的创始人为吉多·范罗苏姆(Guido van Rossum)。1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,做为ABC语言的一种继承。
Python能够应用于众多领域,如:数据分析、组件集成、网络服务、图像处理、数值计算和科学计算等众多领域。目前业内几乎全部大中型互联网企业都在使用Python,如:Youtube、Dropbox、BT、Quora(中国知乎)、豆瓣、知乎、Google、Yahoo!、Facebook、NASA、百度、腾讯、汽车之家、美团等。
 
目前Python主要应用领域:
  云计算: 云计算最火的语言, 典型应用OpenStack
WEB开发: 众多优秀的WEB框架,众多大型网站均为Python开发,Youtube, Dropbox, 豆瓣。。。, 典型WEB框架有Django
科学运算、人工智能: 典型库NumPy, SciPy, Matplotlib, Enthought librarys,pandas
系统运维: 运维人员必备语言
金融: 量化交易,金融分析,在金融工程领域,Python不但在用,且用的最多,并且重要性逐年提升。缘由:做为动态语言的Python,语言结构清晰简单,库丰富,成熟稳定,科学计算和统计分析都很牛逼,生产效率远远高于c,c++,java,尤为擅长策略回测
图形GUI: PyQT, WxPython,TkInter

 

 
 
python是一门动态解释性的强类型定义语言
 
 
 
Python解释器
当咱们编写Python代码时,咱们获得的是一个包含Python代码的以.py为扩展名的文本文件。要运行代码,就须要Python解释器去执行.py文件。
因为整个Python语言从规范到解释器都是开源的,因此理论上,只要水平够高,任何人均可以编写Python解释器来执行Python代码(固然难度很大)。事实上,确实存在多种Python解释器。
 
CPython
当咱们从Python官方网站下载并安装好Python 2.7后,咱们就直接得到了一个官方版本的解释器:CPython。这个解释器是用C语言开发的,因此叫CPython。在命令行下运行python就是启动CPython解释器。
CPython是使用最广的Python解释器。教程的全部代码也都在CPython下执行。
 
IPython
IPython是基于CPython之上的一个交互式解释器,也就是说,IPython只是在交互方式上有所加强,可是执行Python代码的功能和CPython是彻底同样的。比如不少国产浏览器虽然外观不一样,但内核其实都是调用了IE。  
CPython用>>>做为提示符,而IPython用In [序号]:做为提示符。
 
PyPy
PyPy是另外一个Python解释器,它的目标是执行速度。PyPy采用JIT技术,对Python代码进行动态编译(注意不是解释),因此能够显著提升Python代码的执行速度。
绝大部分Python代码均可以在PyPy下运行,可是PyPy和CPython有一些是不一样的,这就致使相同的Python代码在两种解释器下执行可能会有不一样的结果。若是你的代码要放到PyPy下执行,就须要了解PyPy和CPython的不一样点。
 
Jython  
Jython是运行在Java平台上的Python解释器,能够直接把Python代码编译成Java字节码执行。
 
IronPython  
IronPython和Jython相似,只不过IronPython是运行在微软.Net平台上的Python解释器,能够直接把Python代码编译成.Net的字节码。
 
小结
Python的解释器不少,但使用最普遍的仍是CPython。若是要和Java或.Net平台交互,最好的办法不是用Jython或IronPython,而是经过网络调用来交互,确保各程序之间的独立性。
 
2、Python发展史
3、Python 2 or 3?
In summary : Python 2.x is legacy, Python 3.x is the present and future of the language
 
还有谁不支持PYTHON3?
Twisted 
、Python安装
1
2
3
4
5
6
7
1 、下载安装包
     https: / / www.python.org / downloads /
2 、安装
     默认安装路径:C:\python27
3 、配置环境变量
     【右键计算机】 - - 》【属性】 - - 》【高级系统设置】 - - 》【高级】 - - 》【环境变量】 - - 》【在第二个内容框中找到 变量名为Path 的一行,双击】  - - > 【Python安装目录追加到变值值中,用 ; 分割】
     如:原来的值;C:\python27,切记前面有分号
 
1
2
3
无需安装,原装Python环境
   
ps:若是自带 2.6 ,请更新至 2.7
5、Hello World程序
1
print ( "Hello World!" )
1
2
3
localhost:~ jieli$ vim hello.py
localhost:~ jieli$ python hello.py
Hello World!
1
2
3
#!/usr/bin/env python
   
print   "hello,world"
1
2
3
4
5
6
localhost:~ jieli$ python
Python  2.7 . 10   (default,  Oct   23   2015 18 : 05 : 06 )
[GCC  4.2 . 1   Compatible Apple LLVM  7.0 . 0   (clang - 700.0 . 59.5 )] on darwin
Type   "help" "copyright" "credits"   or   "license"   for   more information.
>>>  print ( "Hello World!" )
Hello World!

6、变量\字符编码 
变量用于存储要在计算机程序中引用和操做的信息。 他们还提供了一种以描述性名称标注数据的方法,因此咱们的程序能够被读者和咱们本身更清楚地理解。 将变量视为容纳信息的容器是有帮助的。 它们的惟一目的是将数据标记和存储在内存中。 而后能够在整个程序中使用此数据。
声明变量
name = “lv”
上述代码声明了一个变量,变量名为: name,变量name的值为:"lv"
 
变量定义的规则:
a、变量名只能是字母、数字或下划线的任意组合;
b、变量名的第一个字符不能是数字;
c、如下关键字不能声明为变量名
['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']
 
变量的赋值
python支持中文当变量名
变量和常量
python不支持常量,可是能够用大写字母来表示常量
 
7、字符编码 

python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill)html

ASCII(American Standard Code for Information Interchange,美国标准信息交换代码)是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其余西欧语言,其最多只能用 8 位来表示(一个字节),即:2**8 = 256-1,因此,ASCII码最多只能表示 255 个符号。java

关于中文python

为了处理汉字,程序员设计了用于简体中文的GB2312和用于繁体中文的big5。linux

GB2312(1980年)一共收录了7445个字符,包括6763个汉字和682个其它符号。汉字区的内码范围高字节从B0-F7,低字节从A1-FE,占用的码位是72*94=6768。其中有5个空位是D7FA-D7FE。c++

GB2312 支持的汉字太少。1995年的汉字扩展规范GBK1.0收录了21886个符号,它分为汉字区和图形符号区。汉字区包括21003个字符。2000年的 GB18030是取代GBK1.0的正式国家标准。该标准收录了27484个汉字,同时还收录了藏文、蒙文、维吾尔文等主要的少数民族文字。如今的PC平台必须支持GB18030,对嵌入式产品暂不做要求。因此手机、MP3通常只支持GB2312。程序员

从ASCII、GB23十二、GBK 到GB18030,这些编码方法是向下兼容的,即同一个字符在这些方案中老是有相同的编码,后面的标准支持更多的字符。在这些编码中,英文和中文能够统一地处理。区分中文编码的方法是高字节的最高位不为0。按照程序员的称呼,GB23十二、GBK到GB18030都属于双字节字符集 (DBCS)。web

有的中文Windows的缺省内码仍是GBK,能够经过GB18030升级包升级到GB18030。不过GB18030相对GBK增长的字符,普通人是很难用到的,一般咱们仍是用GBK指代中文Windows内码。shell

显然ASCII码没法将世界上的各类文字和符号所有表示,因此,就须要新出一种能够表明全部字符和符号的编码,即:Unicode  

Unicode(统一码、万国码、单一码)是一种在计算机上使用的字符编码。Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每一个字符设定了统一而且惟一的二进制编码,规定虽有的字符和符号最少由 16 位来表示(2个字节),即:2 **16 = 65536,
注:此处说的的是最少2个字节,可能更多vim

UTF-8,是对Unicode编码的压缩和优化,他再也不使用最少使用2个字节,而是将全部的字符和符号进行分类:ascii码中的内容用1个字节保存、欧洲的字符用2个字节保存,东亚的字符用3个字节保存...windows

因此,python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill),若是是以下代码(python2)的话:

报错:ascii码没法表示中文

1
2
3
#!/usr/bin/env python
   
print   "你好,世界"

改正:应该显示的告诉python解释器,用什么编码来执行源代码,即:

1
2
3
4
#!/usr/bin/env python
# -*- coding: utf-8 -*-
   
print   "你好,世界"

注释:

单行注释:# 被注释内容

多行注释:""" 被注释内容 """       
 
 
 
8、用户输入
格式化输出:(三种方式)
1)
name = input("name:")       #raw_input 适用于pytho2.X input 适用于pytho3.x
age = int(input("age:")) #int=intteger 整形
print(type(age) ,type( str(age)) )
job = input("job:")
salary = input("salary:")
info='''
-----------info of %s---------
name:%s
age:%d
job:%s
salary:%s
'''% (name,name,age,job,salary)
print(info)
%s:string 字符
%d:整数
%f:浮点
打印字符类型
print(type(age))
2)
name = input("name:")       #raw_input 适用于pytho2.X input 适用于pytho3.x
age = int(input("age:")) #int=intteger 整形
job = input("job:")
salary = input("salary:")
info2='''
-----------info2 of {_name}---------
name:{_name}
age:{_age}
job:{_job}
salary:{_salary}
'''.format(_name=name,
_age=age,
_job=job,
_salary=salary)
print(info2)
3)
name = input("name:")       #raw_input 适用于pytho2.X input 适用于pytho3.x
age = int(input("age:")) #int=intteger 整形
job = input("job:")
salary = input("salary:")
info3='''
-----------info3 of {0}---------
name:{0}
age:{1}
job:{2}
salary:{3}
'''.format(name,age,job,salary)
print(info3)
 
 
9、模块初识
Python的强大之处在于他有很是丰富和强大的标准库和第三方库,几乎你想实现的任何功能都有相应的Python库支持。
sys库:
import sys
print(sys.path) #打印环境变量
 
 
 
import sys
print(sys.argv) #打印相对路径
 
import sys
print(sys.argv[2]) 
 
os库:
import os
os.system("dir")
 
import os
cmd_res = os.system("dir") #执行命令,不保存结果
print("-->",cmd_res)
 0即表明成功
 
import os
cmd_res = os.popen("dir").read()  #os.popen 将显示结果放到内存中 还须要再用read将其显示出来
print("-->",cmd_res)
os .mkdir( "new_dir" ) #建立目录
 
调用已经写好的模块以login为例:
 新建一个调入login:
import login
 当调入login和login模块不在同一个目录下,会报错
  此时能够修改环境变量也能够添加路径, 也能够 将login模块放到第三方目录(site-packages)。
10、.pyc文件  
 
 
 
  11、数据类型
一、数字
int(整型)
     在32位机器上,整数的位数为32位,取值范围为-2**31~2**31-1,即-2147483648~2147483647
  在64位系统上,整数的位数为64位,取值范围为-2**63~2**63-1,即-9223372036854775808~9223372036854775807
long(长整型)
  跟C语言不一样,Python的长整数没有指定位宽,即:Python没有限制长整数数值的大小,但实际上因为机器内存有限,咱们使用的长整数数值不可能无限大。
  注意,自从Python2.2起,若是整数发生溢出,Python会自动将整数数据转换为长整数,因此现在在长整数数据后面不加字母L也不会致使严重后果了。
      python3之后就没有长整型了。
float(浮点型)
       先扫盲 http://www.cnblogs.com/alex3714/articles/5895848.html 
  浮点数用来处理实数,即带有小数的数字。相似于C语言中的double类型,占8个字节(64位),其中52位表示底,11位表示指数,剩下的一位表示符号。
complex(复数)
  复数由实数部分和虚数部分组成,通常形式为x+yj,其中的x是复数的实数部分,y是复数的虚数部分,这里的x和y都是实数。
注:Python中存在小数字池:-5 ~ 257
二、布尔值
真 或 假
1  或  0
三、字符串
"hello world"
万恶的字符串拼接:
  python中的字符串在C语言中体现为是一个字符数组,每次建立字符串时候须要在内存中开辟一块连续的空,而且一旦须要修改字符串的话,就须要再次开辟空间,万恶的+号每出现一次就会在内从中从新开辟一块空间。
字符串格式化输出
1
2
3
4
name  =   "alex"
print   "i am %s "   %   name
   
#输出: i am alex

PS: 字符串是 %s;整数 %d;浮点数%f

字符串经常使用功能:
  • 移除空白
  • 分割
  • 长度
  • 索引
  • 切片
四、列表
建立列表:
1
2
3
name_list  =   [ 'alex' 'seven' 'eric' ]
name_list =  list ([ 'alex' 'seven' 'eric' ])

基本操做:

  • 索引
  • 切片
  • 追加
  • 删除
  • 长度
  • 切片
  • 循环
  • 包含
五、元组(不可变列表)
建立元组:
1
2
3
ages  =   ( 11 22 33 44 55 )
ages  =   tuple (( 11 22 33 44 55 ))
 
六、字典(无序)
建立字典:
1
2
3
person  =   { "name" "mr.wu" 'age' 18 }
person  =   dict ({ "name" "mr.wu" 'age' 18 })

经常使用操做:

  • 索引
  • 新增
  • 删除
  • 键、值、键值对
  • 循环
  • 长度
12、数据运算
算数运算:
比较运算:
赋值运算:
逻辑运算:
成员运算:
身份运算;
位运算:
#!/usr/bin/python
  
=  60             # 60 = 0011 1100
=  13             # 13 = 0000 1101
=  0
  
=  a & b;         # 12 = 0000 1100
print  "Line 1 - Value of c is " , c
  
=  a | b;         # 61 = 0011 1101
print  "Line 2 - Value of c is " , c
  
=  a ^ b;         # 49 = 0011 0001 #相同为0,不一样为1
print  "Line 3 - Value of c is " , c
  
=  ~a;            # -61 = 1100 0011
print  "Line 4 - Value of c is " , c
  
=  a <<  2 ;        # 240 = 1111 0000
print  "Line 5 - Value of c is " , c
  
=  a >>  2 ;        # 15 = 0000 1111
print  "Line 6 - Value of c is " , c
*按位取反运算规则(按位取反再加1)   详解http://blog.csdn.net/wenxinwukui234/article/details/42119265
运算符优先级:
 
 
 
十3、表达式 if  else
输入密码不可见,须要利用getpass模块中的getpass方法:
import getpass    #import为python的标准库
username = input("username:")
password = getpass.getpass("password:")
print(username,password)
 
密码验证:  
_username = 'lv'
_password = '123'
username = input("username:")
password = input("password:")
if _username == username and _password == password:
print("Welecom user {name} login..".format(name=username))
else:
print("Invalid username or password!")
结果:
比较大小,使用if elif else:  
age_of_oldboy = 56
guess_age = int(input("guess age:"))
if guess_age == age_of_oldboy :
print("yes,you got it.")
elifguess_age > age_of_oldboy :
print("think smaller...")
else:
print("think bigger!")
 
十4、while循环
最简单的while循环:
 
  
count = 0
while True:
print("count:",count)
count = count +1 #count +=1
if count == 1000:
break
猜三次,三次都错就结束: 涉及到while循环
猜年龄 while:
age_of_oldboy = 56
count = 0
while True:
if count ==3 :
break
guess_age = int(input("guess age:"))
if guess_age == age_of_oldboy :
print("yes,you got it!")
break
elif guess_age >age_of_oldboy :
print("think smaller...")
else:
print("think bigger...")
count +=1
 
while循环优化:
age_of_oldboy = 56
count = 0
while count <3:
guess_age = int(input("guess age:"))
if guess_age == age_of_oldboy :
print("yes,you got it!")
break
elif guess_age >age_of_oldboy :
print("think smaller...")
else:
print("think bigger...")
count +=1
else :
print("you have tried too many times.. fuck off")
 
十5、for循环:
最简单的循环10次
for i in range(10):
print("loop ",i)
猜年龄 for:
age_of_oldboy = 56
count = 0
for i in range(3):
guess_age = int(input("guess age:"))
if guess_age == age_of_oldboy :
print("yes,you got it!")
break
elif guess_age >age_of_oldboy :
print("think smaller...")
else:
print("think bigger...")
count +=1
else :
print("you have tried too many times.. fuck off")
 
猜年龄 任意玩:
age_of_oldboy = 56
count = 0
# while count <3: while和for均可以
for i in range(4):
guess_age = int(input("guess age:"))
if guess_age == age_of_oldboy :
print("yes,you got it!")
break
elif guess_age >age_of_oldboy :
print("think smaller...")
else:
print("think bigger...")
count +=1
if count == 3:
continue_confirm = input("do you want to keep guessing?")
if continue_confirm != 'n':
count = 0
间断执行for
for i in range(1,10,2):
print("loop ",i)
for循环中的continue continue:跳出本次循环进入下次循环 break:结束本次循环
continue:
for i in range(0,10):
if i<5:
print("loop",i)
else:
continue
print("hehe")
 
 
break:
for i in range(10):
print('-------------',i)
for j in range(10):
print(j)
if j>5:
break

做业二:编写登录接口

  • 输入用户名密码
  • 认证成功后显示欢迎信息
  • 输错三次后锁定
 
bytes类型(字节类型  二进制类型)
Python3的bytes/str(字符串)之别(http://www.ituring.com.cn/article/1116
 
三元运算
    result =值1if条件 else值2
若是条件为真:result = 值1
若是条件为假:result = 值2
 
进制
  • 二进制,01
  • 八进制,01234567
  • 十进制,0123456789
  • 十六进制,0123456789ABCDEF  二进制到16进制转换http://jingyan.baidu.com/album/47a29f24292608c0142399cb.html?picindex=1
 
 
 

<wiz_tmp_tag id="wiz-table-range-border" contenteditable="false" style="display: none;">



相关文章
相关标签/搜索