Python开发【第一章】:Python简介跟入门

Python开发【第一章】:Python简介和入门

Python简介

  Python的创始人为Guido van Rossum。1989年圣诞节期间,在阿姆斯特丹,Guido为了打发圣诞节的无趣,决心开发一个新的脚本解释程序,做为ABC 语言的一种继承。之所以选中Python(大蟒蛇的意思)作为程序的名字,是因为他是一个叫Monty Python的喜剧团体的爱好者。

  ABC是由Guido参加设计的一种教学语言。就Guido本人看来,ABC 这种语言非常优美和强大,是专门为非专业程序员设计的。但是ABC语言并没有成功,究其原因,Guido 认为是非开放造成的。Guido 决心在Python 中避免这一错误。同时,他还想实现在ABC 中闪现过但未曾实现的东西。

  就这样,Python在Guido手中诞生了。可以说,Python是从ABC发展起来,主要受到了Modula-3(另一种相当优美且强大的语言,为小型团体所设计的)的影响。并且结合了Unix shell和C的习惯。

  Python  已经成为最受欢迎的程序设计语言之一。2011年1月,它被TIOBE编程语言排行榜评为2010年度语言。自从2004年以后,python的使用率是呈线性增长 。

 

Python入门

 一、python安装

windows系统:

1、下载安装包
    https://www.python.org/downloads/
2、安装
    默认安装路径:C:python35
3、配置环境变量
    【右键计算机】--》【属性】--》【高级系统设置】--》【高级】--》【环境变量】--》【在第二个内容框中找到 变量名为Path 的一行,双击】 --> 【Python安装目录追加到变值值中,用 ; 分割】
    如:原来的值;C:python35,切记前面有分号

linux系统:

无需安装,原装Python环境
ps:如果自带2.6,请更新至2.7

 

二、python初试

在 /home/python/ 目录下创建 hello.py 文件,内容如下

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#-Author-Lian

print ("Hello World!")

执行: ./hello.py      注:执行前需给予 hello.py 执行权限,chmod 755 hello.py

 

三、变量赋值及命名规则

声明一个变量name,变量name的值为:“lzl”

#!/usr/bin/env python
# -*- coding: utf-8 -*-
 
name = "lzl"

变量命名的规则

变量定义的规则:

变量名只能是 字母、数字或下划线的任意组合
变量名的第一个字符不能是数字
以下关键字不能声明为变量名
['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 li,变量name2赋值为变量name1,name1重赋值Jack Chen,此时name2的值为多少?)

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#-Author-Lian
name1 = "Alex Li"

name2 = name
print(name1, name2)

name1 = "Jack Chen"

print("What is the value of name2 now?")

由图所示,所以最后name1的值为Jack Chen,name2的值为Alex li

 

 四、字符编码

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码无法表示中文

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

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

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

注:python2.x版本,默认支持的字符编码为ASCll    python3.x版本,默认支持的是Unicode,不用声明字符编码可以直接显示中文

 

五、用户交互及字符串拼接

跟用户进行交互,并把输入的信息打印出来

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#-Author-Lian
###########用户交互及字符串拼接################
# python2.X与python3.X区别:    python2.X raw_input = python3.X input
# 提示用户输入姓名、年龄、工作、工资并以信息列表的形式打印出

name = input("Please input your name:")
age = int(input("Please input your age:"))  #str强制转换为int
job = input("Please input your job:")
salary = input("Please input your salary:")

info1 = '''
------------  Info of %s  ---------
Name:%s
Age:%d
Job:%s
Salary:%s
''' %(name,name,age,job,salary)     #%s检测数据类型为字符串,%d检测数据类型为整数,%f检测数据类型为浮点数 强制
print(info1)

info2 = '''
------------  Info of {_Name}  ---------
Name:{_Name}
Age:{_Age}
Job:{_Job}
Salary:{_Salary}
''' .format(_Name=name,
            _Age=age,
            _Job=job,
            _Salary=salary)
print(info2)

info3 = '''
------------  Info of {0}  ---------
Name:{0}
Age:{1}
Job:{2}
Salary:{3}
''' .format(name,age,job,salary)
print(info3)

 

六、if判断语句

实例:用if语句验证用户登录,密文密码

#!/usr/bin/env python # -*- coding:utf-8 -*- #-Author-Lian #############验证用户登录-密文密码############## # 提示输入用户名密码 # 验证用户名密码 #       如果错误,则输出用户名密码错误 #       如果成功,则输出欢迎,xxx! import getpass     #标准模块,import调用 name = input("Please input your name:") password = getpass.getpass("Please input your password:") if name == "lzl" and pwd == "[email protected]":     print ("Welcome to,lzl!") else:     print ("The user name and password mistake") 

实例:用if语句实现猜幸运数字游戏

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#-Author-Lian
##############猜幸运数字################
# 提示用户输入猜的幸运数字(1-100)
# 根据输入的数字做判断
#         如果猜对,输出恭喜你猜对了
#         如果猜的数字大了,输出数字往小点猜
#         否则,输出数字往大点猜

lucky_num = 66

guess_num = int(input("Please enter your guess lucky number(1-100):"))

if guess_num == lucky_num:
    print ("Congratulations you guessed it!")
elif guess_num > lucky_num :
    print ("Think it smaller...")
else:
    print ("Think it bigger...")

 

七、while循环语句

实例:猜数字游戏升级版(循环猜数字,直到猜到为止)

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#-Author-Lian
##############猜幸运数字################

lucky_num = 66       # 设置幸运数字

while True:    # while循环:
                     # 输入猜的的幸运数字范围1-100
    guess_num = int(input("Please enter your guess lucky number(1-100):"))

    if guess_num == lucky_num:      # 如果猜对,输出恭喜你猜对了,并退出
        print ("Congratulations you guessed it!")
        break                       #break 结束循环 continue 跳出本次循环,继续下次循环 exit 结束程序
    elif guess_num > lucky_num :    # 如果猜的数字大了,输出数字往小点猜
        print ("Think it smaller...")
    else:                           # 否则,输出数字往大点猜
        print ("Think it bigger...")
    

实例:猜数字游戏完善版(循环猜数字,允许猜三次机会)

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#-Author-Lian
##############猜幸运数字+次数限制################

lucky_num = 66       # 设置幸运数字
count = 0            # 设置初始值count=0

while count < 3 :    # while判断count是否小于3,如果小于3则:
                     # 输入猜的的幸运数字范围1-100
    guess_num = int(input("Please enter your guess lucky number(1-100):"))

    if guess_num == lucky_num:      # 如果猜对,输出恭喜你猜对了,并退出
        print ("Congratulations you guessed it!")
        break                       #break 结束循环 continue 跳出本次循环,继续下次循环 exit 结束程序
    elif guess_num > lucky_num :    # 如果猜的数字大了,输出数字往小点猜
        print ("Think it smaller...")
    else:                           # 否则,输出数字往大点猜
        print ("Think it bigger...")
    count += 1                       #每次循环结束count加1
else:
    print ("You tried so many times!")  #while循环超过三次,则输出试过太多次了

 

八、for循环语句

实例:用for循环实现猜数字游戏,限制三次机会

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#-Author-Lian
##############猜幸运数字+次数限制################

lucky_num = 66       # 设置幸运数字

for i in range(3):    # while判断count是否小于3,如果小于3则:
                     # 输入猜的的幸运数字范围1-100
    guess_num = int(input("Please enter your guess lucky number(1-100):"))

    if guess_num == lucky_num:      # 如果猜对,输出恭喜你猜对了,并退出
        print ("Congratulations you guessed it!")
        break                       #break 结束循环 continue 跳出本次循环,继续下次循环 exit 结束程序
    elif guess_num > lucky_num :    # 如果猜的数字大了,输出数字往小点猜
        print ("Think it smaller...")
    else:                           # 否则,输出数字往大点猜
        print ("Think it bigger...")
else:
    print ("You tried so many times!")  #while循环超过三次,则输出试过太多次了

 

九、扩展

① 编写登陆接口 要求:

  • 输入用户名密码
  • 认证成功后显示欢迎信息
  • 输错三次后锁定

# 流程图如下:         

 # login_interface.py 程序代码

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#-Author-Lian
################登录接口程序################

# -*-      运行环境python3.5.2   -*-
#user_information、locked_information、day1_login_interface.py三个文件拷贝到同一级目录
#授权:chmod 755  day1_login_interface.py
#执行:python  day1_login_interface.py

####记录可登录用户、密码信息文件user_information####
# Dave    dave123
# John    john123
# Luffy    luffy123
####记录被锁定的用户信息文件locked_information####
# lzl
# Alex

#
Count = 1                           #设置计数器,统计下面第一个while大循环的次数 赋值变量Count,初始值为1
Last_user = ""                     #针对上次登录的用户名进行记录,如果连续三次登录错误的用户名是一致的话才进行锁定
                                    #赋值变量Last_user,初始值为空
Match_count = 1                     #统计Last_user与上次登录的用户名匹配的次数,变量Match_count初始值为1

while True:
    Locked = open("locked_information", "r")  # 读取被锁定用户名信息文件
    User_pwd = open("user_information", "r")  # 读取可登录的用户、密码信息文件

    User = input("Please enter the login username:")            #提示用户输入登录用户名并赋值给User
    Passwd = input("Please enter login password:")              # 提示用户输入登录密码并赋值给Passwd

    if len(User) == 0:
        print("Error:Enter the user is null! please try again..")
        continue
    if Last_user == User:           #if语句判断,本次登录的用户名跟上次登录的用户名是否匹配
        Match_count +=1             #如果匹配成功,表示两次连续登录的用户名一致,Match_count计数加1
    else:                           #如果匹配失败,Match_count计数恢复为初始值1
        Match_count = 1

    Re_count = 3 - Count            #设置变量Re_count为还进行登录的剩余次数,判断登录失败后会用到


    for Blacklist in Locked.readlines():            #for循环读取被锁定用户名,生成变量Blacklist
        Blacklist = Blacklist.strip("n")           #对变量Blacklist进行去换行符操作
        if User == Blacklist:                   #判断如果输入的用户名在Blacklist中,则提示用户被锁定并退出登录
            print ("Login username ",User," is locked, login fails...")
            exit()                                #退出程序

    for i_f_m in User_pwd.readlines():              #for循环读取可登录用户、密码信息文件,赋值变量i_f_m
        i_f_m = (i_f_m.strip("n")).split()             #对变量i_f_m进行先去换行符,然后以空格符分割为列表的操作
        if User == i_f_m[0] and Passwd == i_f_m[1]:     #对登录用户名和密码进行匹配,两者都匹配成功则显示恭喜登陆成功
            print ("Congratulations to login successful!")
            exit()                                #退出程序
            print(User,Passwd)

    else:
        if Re_count > 0 :    #验证上面for循环匹配失败并且剩余登录次数大于0后,提示错误和剩余次数
                             #如果去掉if判断,则在匹配用户锁定时打印信息重合,放到下面while循环里面则会添加多余输出
            print("Error: The username and password mistate!  You can also try", Re_count, "times...")

        while Re_count > 0 :    #while循环语句,重试登录次数大于0时,提示用户是否还要继续登陆
            If_cont = input("Whether or not to continue to login?(Y/N):")
            if If_cont == "Y":                  #匹配字符Y
                break                           #跳出当前while,重新输入用户名密码
            elif If_cont == "N":                #匹配字符N
                print ("-- Bye --")
                exit()                           #终止程序
            else:                               #字符输入错误,重新提示输入正确的字符Y 和 N
                print("*        Please enter 【Y】 or 【N】        *")
                continue                        #跳出当前循环执行下次循环
        else:                   #while循环语句,当用户重试登录次数为0时,执行下面语句
            if Match_count == 3:                #连续三次输入的用户名一致,把用户名加入到黑名单
                Locked = open("locked_information", "a")    #对文件locked_information追加写操作
                Locked.write(User + "n")       #把用户名写入到黑名单并执行下换行符
                print("Error: The username and password mistate! The current user ",User," is locked...")
                break                           #提示锁定用户并退出程序
            else:                               #连续三次输入的用户名不一致,提示用户名密码错误,不进行锁定
                print ("Error: The username and password mistate! Bye-bye!")
                break                          #退出程序

    Count +=1                                   #循环结束,Count计数加1
    Last_user = User                            #循环结束,Last_userc重新赋值
Locked.close()
User_pwd.close()
login_interface.py

 # 程序 readme

# 这是一个模拟真实用户登录系统的程序

### 作者介绍:
* author:lzl
### 博客地址:
* http://www.cnblogs.com/lianzhilei/p/5703675.html

### 实现效果:
* user_information文件记录了可登录用户名和密码,每次登录只有完全匹配文件中的用户名和密码才能登录
* locked_information文件记录了被锁定的用户,每次登录输入被锁定的用户,会提示当前用户被锁定,并退出
* 用户连续三次登录失败且三次输入的用户名一样,会显示当前用户被锁定,退出程序并且把用户名记录到locked_information
* 用户连续三次登录失败,但三次的用户名不一样,提示登录失败,退出程序用户名不锁定
* 前两次登录失败时可选择是否还要继续登录,登录失败时会显示剩余登录次数

### Bug 可完善的地方:
* 随意输入任何用户名都可进行登录,即使不存在与user_information文件中也可被锁定
* 输入的密码时可以改成密文的形式

### 运行环境:
* Python3.0+ 最佳Python3.5.2


### 目录结构:

    Day1
    ├── 登录接口
    │   ├── day1_login_interface.py
    │   └── locked_information
    │   ├── user_information
    │   ├── login_interface.png
    │   └── readme

### linux 运行说明:

* user_information、locked_information、day1_login_interface.py拷贝到同一级目录下
* 加执行权限 chmod 755  day1_login_interface.py
* 执行程序   python  day1_login_interface.py
readme

 

多级菜单,查询街道/地区邮政编码

  • 三级菜单
  • 可依次选择进入各子菜单
  • 子菜单实现b可以返回,q可以退出

 # 流程图如下

multistage_menu.py程序代码如下:

#!/usr/bin/env python
# -*- coding:utf-8 -*-
#-Author-Lian
################多级菜单,查询街道/地区邮政编码################

# -*-      运行环境python3.5.2   -*-
#授权:chmod 755  day1_multistage_menu.py
#执行:python  day1_multistage_menu.py
#注:定义Main_menu主菜单  字典套字典套列表形式

Main_menu = {                               #定义主菜单Main_menu作为数据库
    '北京':{
        '石景山区':['八宝山街道','老山街道','八角街道','古城街道','苹果园街道','金顶街街道','广宁街道','鲁谷社区'],
        '朝阳区':['和平街街道','朝外街道','劲松街道','建外街道','呼家楼街道','八里庄街道','三里屯街道','潘家园街道'],
        '昌平区':['城北街道','城南街道','天通苑北街道','天通苑南街道','霍营街道','回龙观街道','龙泽园街道','史各庄街道'],
        '东城区':['安定门街道','建国门街道','东直门街道','天坛街道','东四街道','龙潭街道','前门街道','景山街道'],
        '海淀区':['清华园街道','香山街道','清河街道','上地街道','万柳地区','中关村街道','海淀街道','学院路街道']
            },
    '上海':{
        '黄浦区':['南京东路街道','外滩街道','半淞园路街道','小东门街道','豫园街道','老西门街道','五里桥街道','淮海中路街道'],
        '浦东新区':['潍坊新村街道','陆家嘴街道','周家渡街道','塘桥街道','洋泾街道','东明路街道','花木街道','浦兴路街道'],
        '徐汇区':['湖南路街道','天平路街道','枫林路街道','徐家汇街道','斜土路街道','长桥街道','龙华街道','田林街道'],
        '长宁区':["华阳路街道","新华路街道","江苏路街道","天山路街道","周家桥街道","虹桥街道","仙霞新村街道","程家桥街道"],
        '杨浦区':['定海路街道','平凉路街道','江浦路街道','四平路街道','控江路街道','长白新村街道','延吉新村街道','殷行街道']
            },
    '香港':{
        '香港岛':['中西区','湾仔区','东区','南区','石澳','大浪湾','夏萍湾','龟背湾'],
        '九龙半岛':['油尖旺区','深水埗区','九龙城区','黄大仙区','观塘区','维多利亚港','旺角','新蒲岗'],
        '新界':['北区','大埔区','沙田区','西贡区','荃湾区','屯门区','元朗区','葵青区'],
        '港岛区':['中环','湾仔','南区','太平山','尖沙咀','钻石山','山顶','大屿山'],
        '九龙区':['龙门','九龙','侯王庙','万佛寺','东普陀','青松观','妙法寺','灵渡寺']
            }
}

import random                             #调用random,生成邮编码

while True:
    Num_ct = 1                      #城市ID序号,初始值1

    Dic_city = {}                    #定义字典,初始值空
    Dic_county = {}
    Dic_street = {}
    print("               -*-   邮政编码查询系统   -*-")
    for City in Main_menu.keys():                       #循环 把可选的城市赋值给变量City
        print ("",Num_ct,City)                              #打印ID序号和城市名
        Dic_city[Num_ct] = City                             #绑定ID序号和城市名,生成字典Dic_city
        Num_ct +=1                                           #每次循环ID序号+1
    print( " q", "退出程序")
    City_id = input("请输入要查询城市的ID序号 :")           #for循环结束,输入要选择的城市ID 注:此时输入的类型为字符串
    if City_id == "q":  # 判断输入是否为q 退出程序
         print("    -*-   Bye-bye!    -*-")
         exit()
    elif City_id in ['1','2','3']:                          #匹配输入是否为1,2,3
        City_id = int(City_id)                                #字符类型转换  注:如果不转换,下面字典匹配不到key值
        Sec_menu = (Main_menu.get((Dic_city.get(City_id))))     #定义二级菜单,生成二级数据库

        while True:                                     #while 循环
            Num_co = 1                                                #市区ID序号,初始值1
            for County in Sec_menu.keys():                            #循环 把可选的市区赋值给变量County
                print("",Num_co, County)                               #打印ID序号和市区名
                Dic_county[Num_co] = County                             #绑定ID序号和市区名,生成字典Dic_county
                Num_co += 1                                             #每次循环ID序号+1
            print(" b", "返回上级重新选择城市", "n", "q", "退出程序")
            County_id = input("请输入要查询城区的ID序号 :")            #输入要选择的市区ID
            if County_id == "b":                                        #判断输入是否为b 返回上级菜单
                break
            elif County_id == "q":                                      #判断输入是否为q 退出程序
                print("    -*-   Bye-bye!    -*-")
                exit()
            elif County_id in ['1','2','3','4','5']:                   #判断输入是否为1-5
                County_id = int(County_id)                                 #字符类型转换
                Third_menu = (Sec_menu.get((Dic_county.get(County_id))))    #定义三级菜单,生成三级数据库

                while True:                                   #while 循环
                    Num_st = 1                                           #街道数字标号,初始值1
                    for Street in Third_menu:                           #循环 把可选的街道赋值给变量Street
                        print ("",Num_st,Street)                         #打印ID序号和街道名
                        Dic_street[Num_st] = Street                       #绑定ID序号和市区名,生成字典Dic_street
                        Num_st +=1                                         #每次循环ID序号+1
                    print (" b","返回上级重新查询城区","n","q","退出程序")
                    Street_id = input("请输入要查询街道/区域的ID序号 :")        #输入要选择的街道ID序号
                    if Street_id == "b":                                    #判断输入是否为b 返回上级菜单
                        break
                    elif Street_id == "q":                                  #判断输入是否为q 退出程序
                        print("    -*-   Bye-bye!    -*-")
                        exit()
                    elif Street_id in ['1', '2', '3', '4', '5','6','7','8']:    #判断输入是否为1-8
                        Street_id = int(Street_id)                              #字符类型转换

                        print("您查询的地址:",Dic_city.get(City_id),Dic_county.get(County_id),Dic_street.get(Street_id),
                              "   邮政编码为:",random.randint(100000,300000))   #查询成功 输出
                        exit()                                                  #查询成功 退出
                        ####留位####注:如果还行输入成功后加判断是否继续查询,可在此加代码


                    else:                   #输入格式错误,提示
                        print("           输入的格式错误!请重新输入数字 1 & 2 &  ...  & 7 & 8 或字符 b & q")

            else:                           #输入格式错误,提示
                print("           输入的格式错误!请重新输入数字 1 & 2 & 3 & 4 & 5 或字符 b & q")

    else:                                   #输入格式错误,提示
        print("            输入的格式错误!请重新输入数字 1 & 2 & 3 或 字符 q")
multistage_menu.py

# 程序 readme

# 这是一个模拟查询街道/地区邮政编码的程序
# 多级菜单,使用了字典套字典套列表的形式

### 作者介绍:
* author:lzl
### 博客地址:
* http://www.cnblogs.com/lianzhilei/p/5703675.html

### 实现效果:
* 进入程序每级菜单可选择要查询的ID序号,选择序号会进入到相应的地区子菜单中
* 每级菜单都可输入b返回上一级菜单,输入q可退出程序
* 任何一级菜单输入错误的字符,会提示重新输入ID序号
* 最后三级菜单选择完毕,输入选择地区的邮政编码,查询完成,退出程序

### Bug 可完善的地方:
* 邮政编码由随机数设定,数据不准确
* 由于用到的字典是无序的,所以同一级菜单每次显示的ID序号可能不一样

### 运行环境:
* Python3.0+ 最佳Python3.5.2


### 目录结构:

    Day1
    ├── 三级菜单
    │   ├── day1_multistage_menu.py
    │   ├── multistage_menu.png
    │   └── readme

### linux 运行说明:

* 加执行权限 chmod 755  day1_multistage_menu.py
* 执行程序   python  day1_multistage_menu.py
readme

 

相关内容推荐