pythone--002
元组就是不可修改;
字典的索引不是自增的。 元组和列表是;
默认 是key
通过get 没有这个key 是none
get可以有默认值;
通过索引 没有就报错。
检查字典中某个可以是否存在;has_key 3 没有了用in 代替;
input 输入的都是字符串。
索引整型 要转。
int(inp);
range (用来获取指定范围内的数)
range(0,100000);
会在内存里一下创建这么多
xrange(2.7 有)
xrange(0,100000);
只有在循环的时候创建;
for i in xrange(1,1000):
print(i);
每次创建一个。
3.5 range 相当于 xrange
Python环境
安装Python
windows:
12345671
、下载安装包
https:
/
/
www.python.org
/
downloads
/
2
、安装
默认安装路径:C:\python27
3
、配置环境变量
【右键计算机】
-
-
》【属性】
-
-
》【高级系统设置】
-
-
》【高级】
-
-
》【环境变量】
-
-
》【在第二个内容框中找到 变量名为Path 的一行,双击】
-
-
> 【Python安装目录追加到变值值中,用 ; 分割】
如:原来的值;C:\python27,切记前面有分号
linux:
123无需安装,原装Python环境
ps:如果自带
2.6
,请更新至
2.7
更新Python
windows:
1卸载重装即可
linux:
Linux的yum依赖自带Python,为防止错误,此处更新其实就是再安装一个Python
12345678910111213141516171819查看默认Python版本
python
-
V
1
、安装gcc,用于编译Python源码
yum install gcc
2
、下载源码包,https:
/
/
www.python.org
/
ftp
/
python
/
3
、解压并进入源码文件
4
、编译安装
.
/
configure
make
all
make install
5
、查看版本
/
usr
/
local
/
bin
/
python2.
7
-
V
6
、修改默认Python版本
mv
/
usr
/
bin
/
python
/
usr
/
bin
/
python2.
6
ln
-
s
/
usr
/
local
/
bin
/
python2.
7
/
usr
/
bin
/
python
7
、防止yum执行异常,修改yum使用的Python版本
vi
/
usr
/
bin
/
yum
将头部
#!/usr/bin/python 修改为 #!/usr/bin/python2.6
Python 入门
一、第一句Python代码
在 /home/dev/ 目录下创建 hello.py 文件,内容如下:
1
|
print "hello,world" |
执行 hello.py 文件,即: python /home/dev/hello.py
python内部执行过程如下:
二、解释器
上一步中执行 python /home/dev/hello.py 时,明确的指出 hello.py 脚本由 python 解释器来执行。
如果想要类似于执行shell脚本一样执行python脚本,例: ./hello.py
,那么就需要在 hello.py 文件的头部指定解释器,如下:
1
2
3
|
#!/usr/bin/env python print "hello,world" |
如此一来,执行: ./hello.py
即可。
ps:执行前需给予 hello.py 执行权限,chmod 755 hello.py
三、内容编码
python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill)
ASCII(American Standard Code for Information
Interchange,美国标准信息交换代码)是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其他西欧语言,其最多只能用 8
位来表示(一个字节),即:2**8 = 256,所以,ASCII码最多只能表示 256 个符号。
显然ASCII码无法将世界上的各种文字和符号全部表示,所以,就需要新出一种可以代表所有字符和符号的编码,即:Unicode
Unicode(统一码、万国码、单一码)是一种在计算机上使用的字符编码。Unicode
是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,规定虽有的字符和符号最少由 16
位来表示(2个字节),即:2 **16 = 65536,
注:此处说的的是最少2个字节,可能更多
UTF-8,是对Unicode编码的压缩和优化,他不再使用最少使用2个字节,而是将所有的字符和符号进行分类:ascii码中的内容用1个字节保存、欧洲的字符用2个字节保存,东亚的字符用3个字节保存...
所以,python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill),如果是如下代码的话:
报错:ascii码无法表示中文
1
2
3
|
#!/usr/bin/env python print "你好,世界" |
改正:应该显示的告诉python解释器,用什么编码来执行源代码,即:
1
2
3
4
|
#!/usr/bin/env python # -*- coding: utf-8 -*- print "你好,世界" |
四、注释
当行注视:# 被注释内容
多行注释:""" 被注释内容 """
五、执行脚本传入参数
Python有大量的模块,从而使得开发Python程序非常简洁。类库有包括三中:
- Python内部提供的模块
- 业内开源的模块
- 程序员自己开发的模块
Python内部提供一个 sys 的模块,其中的 sys.argv 用来捕获执行执行python脚本时传入的参数
1
2
3
4
5
6
|
#!/usr/bin/env python # -*- coding: utf-8 -*- import sys print sys.argv |
六、 pyc 文件
执行Python代码时,如果导入了其他的 .py 文件,那么,执行过程中会自动生成一个与其同名的 .pyc 文件,该文件就是Python解释器编译之后产生的字节码。
ps:代码经过编译可以产生字节码;字节码通过反编译也可以得到代码。
七、变量
1、声明变量
1
2
3
4
|
#!/usr/bin/env python # -*- coding: utf-8 -*- name = "wupeiqi" |
上述代码声明了一个变量,变量名为: name,变量name的值为:"wupeiqi"
变量的作用:昵称,其代指内存里某个地址中保存的内容
变量定义的规则:
- 变量名只能是 字母、数字或下划线的任意组合
- 变量名的第一个字符不能是数字
- 以下关键字不能声明为变量名
['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']
2、变量的赋值
#!/usr/bin/env python
# -*- coding: utf-8 -*- name1 = "wupeiqi"
name2 = "alex"
#!/usr/bin/env python
# -*- coding: utf-8 -*- name1 = "wupeiqi"
name2 = name1
1
2
3
4
5
6
7
8
|
#!/usr/bin/env python # -*- coding: utf-8 -*- # 将用户输入的内容赋值给 name 变量 name = raw_input ( "请输入用户名:" ) # 打印输入的内容 print name |
输入密码时,如果想要不可见,需要利用getpass 模块中的 getpass方法,即:
1
2
3
4
5
6
7
8
9
10
|
#!/usr/bin/env python # -*- coding: utf-8 -*- import getpass # 将用户输入的内容赋值给 name 变量 pwd = getpass.getpass( "请输入密码:" ) # 打印输入的内容 print pwd |
九、流程控制和缩进
需求一、用户登陆验证
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
#!/usr/bin/env python # -*- coding: encoding -*- # 提示输入用户名和密码 # 验证用户名和密码 # 如果错误,则输出用户名或密码错误 # 如果成功,则输出 欢迎,XXX! import getpass name = raw_input ( '请输入用户名:' ) pwd = getpass.getpass( '请输入密码:' ) if name = = "alex" and pwd = = "cmd" : print "欢迎,alex!" else : print "用户名和密码错误" |
需求二、根据用户输入内容输出其权限
1
2
3
4
5
6
|
# 根据用户输入内容打印其权限 # alex --> 超级管理员 # eric --> 普通管理员 # tony,rain --> 业务主管 # 其他 --> 普通用户 |
1
2
3
4
5
6
7
8
9
10
11
|
name = raw_input ( '请输入用户名:' ) if name = = "alex" : print "超级管理员" elif name = = "eric" : print "普通管理员" elif name = = "tony" or name = = "rain" : print "业务主管" else : print "普通用户" |
十、while循环
1、基本循环
1
2
3
4
5
6
|
while 条件: # 循环体 # 如果条件为真,那么循环体则执行 # 如果条件为假,那么循环体不执行 |
2、break
break用于退出所有循环
1
2
3
4
|
while True : print "123" break print "456" |
3、continue
continue用于退出当前循环,继续下一次循环
1
2
3
4
|
while True : print "123" continue print "456" |
#_*_ coding:utf-8 _*_
while
True
:
number
=
int
(
input
(
'请输入数字: '
))
if
number
=
=
7
:
continue
elif
number >
10
:
exit()
print
(number)
2、
1
2
3
4
5
|
number = list ( range ( 1 , 101 )) sum = 0 for i in number: sum = sum + i print ( sum ) |
3、
1
2
3
4
|
number = list ( range ( 1 , 101 )) for i in number: if i % 2 ! = 0 : print (i) |
4、
1
2
3
4
5
|
#_*_ coding:utf-8 _*_ number = list ( range ( 1 , 101 )) for i in number: if i % 2 = = 0 : print (i) |
5、
1
2
3
4
5
6
7
8
9
10
11
|
#_*_ coding:utf-8 _*_ number = list ( range ( 1 , 101 )) sum1 = 0 sum2 = 0 for i in number: if i % 2 ! = 0 : sum1 = sum1 + i else : sum2 = sum2 + i sum = sum1 - sum2 print ( sum ) |
6、
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
#_*_ coding:utf-8 _*_ n = 1 name = 'hahaha' pwd = 'hehehe' while True : username = input ( '请输入用户名: ' ) password = input ( '请输入密码: ' ) if username = = name and password = = pwd: print ( 'hello,%s' % username) exit() else : n = n + 1 if n > 3 : exit() |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
#!/usr/bin/env python # -*- coding:utf-8 -*- #求1-100的所有数的和 start = 1 sum = 0 max_num = raw_input ( 'The max number add is: ' ) while start < = int (max_num): sum = sum + start start + = 1 print sum #输出1-100内的所有奇数 #思路:奇数对2求余得1 start = 1 while start< = 100 : if start % 2 = = 1 : print start start + = 1 #输出1-100内的所有偶数 #思路:偶数对2求余得0 start = 1 while start< = 100 : if start % 2 = = 0 : print start start + = 1 #求1-2+3-4+5 ... 99的所有数的和 #思路:100以内所有奇数减去所有偶数 start = 1 sum = 0 while start < 100 : if start % 2 = = 1 : sum = sum + start elif start % 2 = = 0 : sum = sum - start else : print ( 'Error' ) start + = 1 print sum #用户登录(三次机会重试) #如果用户名或者密码二者其一不正确,则循环重试,循环次数三次 import getpass time = 1 while time: name = raw_input ( "The user name is: " ) passwd = getpass.getpass( "The password is: " ) if name! = "bill" or passwd! = "123" : if time < 3 : print ( "Please try again" ) time + = 1 continue else : print ( "Sorry, time is over!" ) break else : print ( "Congraulation to you for log in success" ) break |
#用户登陆(三次机会重试)
name = raw_input("Enter username :")
passwd = raw_input("Enter password :")
if name == "wwx" and passwd == "123":
print "Welcome"
else: #name != "wwx" or passwd != "123":
print "username or password wrong!"
print "You have two chances"
name = raw_input("Enter username :")
passwd = raw_input("Enter password :")
if name != "wwx" or passwd != "123":
print "username or password wrong!"
print "You have one chances"
name = raw_input("Enter username :")
passwd = raw_input("Enter password :")
print "You have no chances!"
print "GameOver"
1、使用while循环输入 1 2 3 4 5 6 8 9 10
1
2
3
4
5
6
7
8
9
10
|
import time a = 1 while True : print a time.sleep( 0.5 ) if a = = 6 : a = a + 1 elif a = = 10 : break a = a + 1 |
2、求1-100的所有数的和
1
2
3
4
5
6
7
8
|
a = 1 b = 0 while True : b = b + a if a = = 100 : break a = a + 1 print b |
3、输出 1-100 内的所有奇数
1
2
3
4
5
6
7
|
a = 1 while True : if a % 2 = = 1 : print a if a = = 100 : break a = a + 1 |
4、输出 1-100 内的所有偶数
1
2
3
4
5
6
7
|
a = 1 while True : if a % 2 = = 0 : print a if a = = 100 : break a = a + 1 |
5、求1-2+3-4+5 ... 99的所有数的和
1
2
3
4
5
6
7
8
9
10
11
12
|
a = 1 c = 0 d = 0 while True : if a % 2 = = 1 : #1.3 c = c + a if a % 2 = = 0 : #2.4 d = d + a if a = = 99 : print c - d break a = a + 1 |
6、用户登陆(三次机会重试)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
# -*- coding:utf-8 -*- num = 1 while True : a = raw_input ( "UserName:" ) b = raw_input ( "PassWord:" ) if a = = "zzq" and b = = "wyzzq8023" : print u "登录成功..." break elif num > 3 : print u "用户名或密码错误..." print u "输入次数达到上限,退出程序..." break else : print u "用户名或密码错误,请重新输入..." num + = 1 continue |
pythone--002的更多相关文章
- 【GoLang】GO语言系列--002.GO语言基础
002.GO语言基础 1 参考资料 1.1 http://www.cnblogs.com/vimsk/archive/2012/11/03/2736179.html 1.2 https://githu ...
- 《zw版·Halcon-delphi系列原创教程》 Halcon分类函数002·AI人工智能
<zw版·Halcon-delphi系列原创教程> Halcon分类函数002·AI人工智能 AI人工智能:包括knn.gmm.svm等 为方便阅读,在不影响说明的前提下,笔者对函数进行了 ...
- php大力力 [002节]mac php环境安装,mamp安装 ,phpMyAdmin启动
php大力力 [002节]mac php环境安装,mamp安装 ,phpMyAdmin启动 每个人机器不一样,我手头是个air book,查了一下现在最好在mac下,用mamp, mamp百科介绍 , ...
- 【面试题002】java实现的单例模式,c++实现单例模式,实现禁止拷贝
[面试题002]java实现的单例模式,c++实现单例模式,实现禁止拷贝 一 c++实现单例模式 保证一个类,在一个程序当中只有一个对象,只有一个实例,这个对象要禁止拷贝,注意这里要区别于java. ...
- [反汇编练习] 160个CrackMe之002
[反汇编练习] 160个CrackMe之002. 本系列文章的目的是从一个没有任何经验的新手的角度(其实就是我自己),一步步尝试将160个CrackMe全部破解,如果可以,通过任何方式写出一个类似于注 ...
- 002 Spring Restful案例
1:工程结构 需要注意的是需要额外导入以下三个包: jackson-annotations-2.6.1.jar jackson-core-2.6.1.jar jackson-databind-2.6. ...
- python----特性002
python特性002:特性是可继承的 #!/usr/local/python3.5/bin/python3 class Person(object): def __init__(self,name) ...
- python解释器内建函数002
001.dict 函数来创建字典 #!/usr/bin/python #!coding:utf-8 if __name__ == "__main__": dct001=dict(h ...
- Python[小甲鱼-002用Python设计第一个游戏]
–Code——————————————————————- print("----------第一个小游戏----------") temp = input("猜一下我现在 ...
- 2017-2018-1 1623 bug终结者 冲刺002
bug终结者 冲刺002 by 20162329 张旭升 今日冲刺任务: 能够显示主菜单和功能 游戏需要提供主菜单让玩家进行游戏设置,同时能能够把地图文件中的信息转换成为图像显示到游戏界面上 能够实现 ...
随机推荐
- mvc之URL篇
一.根据路由系统生成友好的URL ActionLink(this HtmlHelper htmlHelper, string linkText, string actionName); 会根据当前的路 ...
- 2012年东京区域赛 UVAlive6182~6191
暑假训练场 A(UVAL6182). 凯神看了敲掉的题目,还没有看过 #include <iostream> #include <memory.h> using namespa ...
- 虚拟机CentOS的NAT模式联网和SecureCRT远程登录管理工具
Cenos7 发生了很大的变化,不过也是直接配置网络,从启网卡,从启机器,crt链接 https://blog.csdn.net/gebitan505/article/details/54584213 ...
- 基于windows IIS的C语言CGI WEB服务器环境搭建
网页编程对我来说特别亲切,因为我就是从html.ASP.PHP一步步接触编程的.自己的编程爱好也是从那里一点一点被满足.不过离开大学之后很久没有碰过WEB了,最近看到嵌入式中的涉及到的web服务器,了 ...
- 防范SQL注入漏洞攻击
原理:通过拼sql语句,在输入框里输入' ; SHOW TABLES;注入这样的代码, 防范:你把全部的特殊符号都过滤掉(如单引号,双引号),自然就不会被注入 使用mysql_real_escape_ ...
- CentOS 7防火墙开放端口快速方法
这篇文章主要为大家详细介绍了Centos7.1防火墙开放端口的快速方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 例如安装Nagios后,要开放5666端口与服务器连接,命令如下: [ro ...
- spring考试
- php curl文件上传兼容php5.0~5.6各版本
PHP 5.0~5.6 各版本兼容的cURL文件上传 最近做的一个需求,使用PHP cURL上传文件.踩坑若干,整理如下. 不同版本PHP之间cURL的区别 PHP的cURL支持通过给CURL_POS ...
- ORACLE数据导入导出后新数据库中某些表添加操作报错[ORA-12899]
由于项目需要,我在搭建了新的开发环境后,需要将之前环境中的ORACLE数据库导出,再导入到新的开发环境下.当导出导入完成后,使用数据库进行添加操作时 发现针对很多表的添加操作报错,具体报错原因描述为: ...
- Angular 4 子路由
子子路由 现在要为产品组件增加两个子组件 1. 创建productDesc和sellerInfo两个组件 ng g component productDesc ng g component selle ...