一、is

  1. a = 100
  2. b = 100
  3. print(a == b)
  4. print(a is b)

执行输出:

True

True

查看内存地址,使用 id 函数

  1. print(id(a))
  2. print(id(b))

执行输出:

2456839554480

2456839554480

内存地址,相当于门牌号

  1. ![](https://cdn.nlark.com/yuque/0/2020/png/1484428/1597722037114-086c9266-c74e-42a7-bca8-a3e586434562.png)

== 比较的是数值

is 比较的是内存地址

二、小数据池

只有数字和字符串类型

小数据池的作用,就是节省内存

数字: -5~256

这个范围指向的是同一内存地址

字符串,是没有范围的。

字符串:

1.如果含有特殊字符,不存在小数据池

  1. str(单个) * int int > 20 不存在小数据池

其它的数据类型,不存在小数据池。

三、编码

  1. asiic : 字母,数字,特殊字符;8 1个字节表示1个字符。
  2. unicode:万国码:
  3. Q 0000 0001 0000 0001 0000 0001 0000 0001
  4. 中:0000 0101 0000 0001 0000 0001 0000 0001
  5. utf-8:
  6. a: 0000 0001
  7. 欧: 0000 0001 0000 0001
  8. 中: 0000 0001 0000 0001 0000 0001
  9. gbk:国标
  10. a: 0000 0001
  11. 中:0000 0001 0000 0001

1.编码之间的二进制户部识别

2,存储和传输 101010,但是不能是 unicode 的 1010101,因为资源浪费了

数据类型

int

bool

str

byte 与 str 的方法相同

list

dict

  1. python3x 中的编码:
  2. python3x str 在内存中的编码方式是unicodepython3x 中的str不能直接存储,和发送。
  3. bytes 他的编码方式是非unicodeutf-8gbkgb2012.....)。
  4. 对于英文:
  5. str 表现形式:s = 'laonanhai'
  6. 内部编码:unicode
  7. bytes:
  8. 表现形式:s = b'laonanhai'
  9. 内部编码:非unicode.
  10. 对于中文:
  11. str 表现形式: s = '中国'
  12. 内部编码:unicode
  13. bytes: 00000001
  14. 表现形式:s1 = b'\xe4\xb8\xad\xe5\x9b\xbd'
  15. 内部编码:非unicode.

str 不能直接存储和传输

必须要转换为 bytes 类型,才可以。

  1. ![](https://cdn.nlark.com/yuque/0/2020/png/1484428/1597722037114-fb712dd7-dffb-4166-8f65-7d689690448b.png)
  1. s = 'laonanhai'
  2. s1 = b'laonanhai'
  3. print(s)
  4. print(s1)

执行输出:

laonanhai

b’laonanhai’

字符串前面的 b 表示 bytes 类型

四、编码转换

字符串转换为 bytes

  1. s = '中国'
  2. s1 = s.encode('utf-8')
  3. print(s1)

执行输出:

b’\xe4\xb8\xad\xe5\x9b\xbd’

一个 \ 表示一位,上面的输出,可以看出占用了 6 位。

  1. s = 'alex'
  2. s1 = s.encode('utf-8')
  3. print(s1)

执行输出:

b’alex’

转换为 gbk

  1. s = 'hello girl'
  2. s1 = s.encode('gbk')
  3. print(s1)

执行输出:

b’hello girl’

bytes 转换为 str

  1. s1 = b'\xe4\xb8\xad\xe5\x9b\xbd'
  2. s2 = s1.decode(encoding='utf-8')
  3. print(s2)

执行输出:

中国

只有将字符串写入文件或者发送数据时,才需要用到编码转换。

五、考试

考试作业以及答案:

Python基础数据类型考试题

考试时间:两个半小时 满分100分(80分以上包含80分及格)

基础题

1,简述变量命名规范(3分)**

变量是由数字,字母,下划线,任意组合。

变量不能以数字开头。

不能是python中的关键字。

不能太长,不能是中文,要有描述性。

官方推荐: 下划线命名法,单词之间用下划线连接。

2,字节和位的关系。(2分)

8 bit = 1 bytes

8位 = 1字节

3,’太白’使用utf-8编码时,占的位数和字节数,是多少?使用gbk编码时,占的位数和字节数,是多少。(2分)

utf-8 位数:48 字节:6

gbk 位数:32 字节:4

4,默写字符串的十二个功能,并描述其作用。(12分)

capitalize() #首字母大写,其他小写

upper() #字母全部变成大写

lower() #字母全部变成小写

strip() #去除空格,换行,tab键

split() #分割,将字符串切割成列表

isdigit() #判断是否是数字

format() #格式化输出

replace() #替换

startswith() #以什么开头

endswith() #以什么结尾

center() #居中显示

count() #统计关键字出现的次数

5,数字,字符串,列表,元祖,字典对应的布尔值的False分别是什么?(5分)

数字,0

字符串,’’

列表,[]

元祖,()

字典,{}

6,书写Python2与python3中的三个不同。(3分)

1.源代码风格不一样

2x 代码混乱

3x 代码简洁,优美

2.print不同

2x print 字符串

3x print(‘字符串’)

3.默认编码不一样

2x assic

3x utf-8

7,写代码,有如下列表,利用切片实现每一个功能(每题一分,共计4分)

  1. li = [1,3,2,'a',4,'b',5,'c']

1)通过对li列表的切片形成新的列表l3,l3 = [‘1,2,4,5]

  1. li3 = li[::2]

2)通过对li列表的切片形成新的列表l4,l4 = [3,’a’,’b’]

  1. li4 = li[1:-2:2]

3)通过对li列表的切片形成新的列表l5,l5 = [‘c’]

  1. li5 = li[-1].split()

4)通过对li列表的切片形成新的列表l6,l6 = [‘b’,’a’,3]

li6 = li[-3::-2]

组合嵌套题

a,写代码,有如下列表,按照要求实现每一个功能(每题3分,写出一种方法得1分,写出两种方法的3分。此题共9分)(每个都是一行代码实现)

lis = [['k',['qwe',20,{'k1':['tt',3,'1']},89],'ab']]

1)将列表lis中的’tt’变成大写(用两种方式)。

第一种:

lis[0][1][2]['k1'][0] = "TT"

第二种:

lis[0][1][2]['k1'][0] = lis[0][1][2]['k1'][0].upper()

2)将列表中的数字3变成字符串’100’(用两种方式)。

第一种:

lis[0][1][2]['k1'][1] = '100'

第二种:

lis[0][1][2]['k1'][1] = str(lis[0][1][2]['k1'][1] + 97)

3)将列表中的字符串’1’变成数字101(用两种方式)。

第一种:

lis[0][1][2]['k1'][2] = 101

第二种:

lis[0][1][2]['k1'][2] = int(lis[0][1][2]['k1'][2]+'01')

b,写代码,有如下字典,按照要求实现每一个功能(5分)

dic = {'k1':'v1','k2':['alex','sb'],(1,2,3,4,5):{'k3':['2',100,'wer']}}

1)将’k2’对应的值的最后面添加一个元素’23’。

dic['k2'].append('23')

2)将’k2’对应的值的第一个位置插入一个元素’a’。

dic['k2'].insert(0,'a')

3)将(1,2,3,4,5)对应的值添加一个键值对’k4’,’v4’。

dic[(1,2,3,4,5)]['k4'] = 'v4'

4)将(1,2,3,4,5)对应的值添加一个键值对(1,2,3),’ok’。

dic[(1,2,3,4,5)][(1,2,3)] = 'ok'

5)将’k3’对应的值的’wer’更改为’qq’。

dic[(1,2,3,4,5)]['k3'][2] = 'qq'

转化题

Int与str之间如何转化,转换的结果是什么?有没有条件?(1分)

int 转换为str 结果为str 没有条件限制

str 转换为int 结果为int 要求字符串必须由数字组成

Int 与 bool之间如何转化,转换的结果是什么?有没有条件?(1分)

int —> bool 结果为bool 非0即True,0为False 没有条件限制

bool —> int 结果为int True为1,False为0

str 与 bool之间如何转化,转换的结果是什么?有没有条件?(1分)

str —> bool 结果为true,没有条件限制

str 与 list 能否转化?如何转化?(1分)

可以,

str —> list

使用split()方法

list —> str

使用join()方法

10,实现下列结果(5分)。

1)有列表li = [‘alex’,’wusir’,’rain’]通过操作该列表构造一个字符串s=’alexwusirrain’

s = ''.join(li)

2)有列表li = [‘alex’,’wusir’,’rain’]通过操作该列表构造一个字符串s=’alexwusirrain’

s = '*'.join(li)

3)有字符串s = ‘alexwusirlex’,通过操作该字符串构造一个列表li = [‘a’,’exwusirlex’]

li = s.split('l')

4)有字符串s = ‘alex wusir’,通过操作该字符串构造一个列表li = [‘alex’,’wusir’]

li = s.split()

5)有字符串s = ‘alex’通过操作该字符串构造一个字符串s1 = ‘a_l_e_x’

s1 = '_'.join(s)

11,分别使用while循环,和for循环打印1-2+3-4+5…….+99的结果。(10分)

for循环:

the_sum = 0
for i in range(1,100):
    #print(i)
    if i % 2 == 1:
        the_sum += i
    else:
        the_sum -= i
print(the_sum)

while循环:

count = 1
the_sum = 0
while count < 100:
    if count % 2 == 1:
        the_sum += count
    else:
        the_sum -= count
    count += 1
print(the_sum)

12,使用range打印100,99,98,….1,0(2分)

for i in range(100,-1,-1):
    print(i)

13,计算用户输入内容中索引为奇数并且对应的元素为数字的个数(没有则个数为零)(6分)

comment = input("请输入内容:").strip()
count = 0
for i in comment:
    # 判断索引是否为奇数,同时索引对应的值是数字
    if comment.index(i) % 2 == 1 and i.isdigit():
        count += 1
print(count)

补充代码**

14.有如下值li= [11,22,33,44,55,77,88,99,90],将所有大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值中。**(6分)**

li = [11,22,33,44,55,77,88,99,90]
result = {}
for row in li:
......

li = [11,22,33,44,55,77,88,99,90]
result = {'k1':[],'k2':[]}
for row in li:
    if row > 66:
        result['k1'].append(row)
    else:
        result['k2'].append(row)

print(result)

15,查找列表li中的元素,移除每个元素的空格,并找出以’A’或者’a’开头,并以’c’结尾的所有元素,并添加到一个新列表中,最后循环打印这个新列表。(3分)

li = ['taibai ','alexC','AbC ','egon',' Ritian',' Wusir','  aqc']

li = ['taibai ','alexC','AbC ','egon',' Ritian',' Wusir','  aqc']
li_new = []
for i in li:
    i = i.strip()
    if (i.startswith("a") or i.startswith("A")) and i.endswith("c"):
        li_new.append(i)

print(li_new)

16,实现一个整数加法计算器:(3分)

如:content = input(‘请输入内容:’) # 如用户输入:5+8+7….(最少输入两个数相加),然后进行分割再进行计算,将最后的计算结果添加到此字典中(替换None):

dic={‘最终计算结果’:None}。

content = input('请输入内容:').strip()
the_sum = 0
dic = {'最终计算结果': None}

for i in content.split('+'):
    i = i.strip()
    the_sum += int(i)

dic['最终计算结果'] = the_sum
print(dic)

17,按要求完成下列转化(如果按照索引去做,只能得4分)。(6分)

list3 = [
    {"name": "alex", "hobby": "抽烟"},
    {"name": "alex", "hobby": "喝酒"},
    {"name": "alex", "hobby": "烫头"},
    {"name": "alex", "hobby": "Massage"},
    {"name": "wusir", "hobby": "喊麦"},
    {"name": "wusir", "hobby": "街舞"},
]

如何把上面的列表转换成下方的列表?

list4 = [
    {"name": "alex", "hobby_list": ["抽烟", "喝酒", "烫头", "Massage"]},
    {"name": "wusir", "hobby_list": ["喊麦", "街舞"]},
]

18,写程序:模拟公司hr录入员工账号密码的程序。(10分)

1),员工的账号密码存储在这种数据类型中:

user_list = [
    {'username':'barry','password':'1234'},
    {'username':'alex','password':'asdf'},
    .........
             ]

2)非法字符模板:board = [‘张三’,’李小四’,’王二麻子’]

3)Hr输入用户名,密码(可持续输入,如果想终止程序,那就在输入用户名时输入Q或者q退出程序),在Hr输入用户名时,检测此用户名是否有board里面的非法字符,如果有非法字符,则将非法字符替换成同数量的(如王二麻子替换成*),然后添加到user_list中,如果没有非法字符,则直接添加到user_list中,每次添加成功后,打印出刚添加的用户名,密码。

user_list = [
    {'username':'barry','password':'1234'},
    {'username':'alex','password':'asdf'}
]
board = ['张三','李小四','王二麻子']
while True:

    user = input('请输入姓名: q/Q退出 ').strip()
    if user.upper() == 'Q': break
    else:
        pwd = input('请输入密码:').strip()
        # 遍历关键词列表
        for j in board:
            if j in user:
                user = user.replace(j, '*' * len(user_list))
        #添加到字典中
        user_list.append({'username': user, 'password': pwd})
        print('刚添加的用户名为\t{},密码是\t{}'.format(user, pwd))

周末作业

写一个购物车,写完了的写三级菜单。

购物车

功能要求:

要求用户输入总资产,例如:2000

显示商品列表,让用户根据序号选择商品,加入购物车

购买,如果商品总额大于总资产,提示账户余额不足,否则,购买成功。

goods = [{"name": "电脑", "price": 1999},
           {"name": "鼠标", "price": 10},
      {"name": "游艇", "price": 20},
      {"name": "美女", "price": 998},
]

升级作业:

程序: 三级菜单

要求:

  1. 打印省、市、县三级菜单

  2. 可返回上一级

  3. 可随时退出程序

答案

重点讲解第 17 题,抽烟,喝酒,烫头

最 low 方法

list3 = [
    {"name": "alex", "hobby": "抽烟"},
    {"name": "alex", "hobby": "喝酒"},
    {"name": "alex", "hobby": "烫头"},
    {"name": "alex", "hobby": "Massage"},
    {"name": "wusir", "hobby": "喊麦"},
    {"name": "wusir", "hobby": "街舞"},
]
list4 = [
    {"name": "alex", "hobby_list": []},
    {"name": "wusir", "hobby_list": []},
]
for i in list3:
    if i['name'] == 'alex':
        list4[0]['hobby_list'].append(i['hobby'])
    else:
        list4[1]['hobby_list'].append(i['hobby'])


print(list4)

第一种方法(推荐)

dic = {}  # 声明一个空字典
for i in list3:  # 遍历列表
    if i['name'] not in dic:  # 判断name不在字典里面时
        # 新添加一个key
        dic[i['name']] = {'name':i['name'],'hobby_list':[i['hobby'],]}
        # print(dic)  字典的值就是下面的
        #dic = {'alex':{"name": "alex", "hobby_list": ["抽烟",],
        #        'wusir':{"name": "wusir", "hobby_list": ["喊麦",]}
    else:
        # 如果存在,就添加爱好列表
        dic[i['name']]['hobby_list'].append(i['hobby'])


print(list(dic.values()))

执行输出:

[{‘hobby_list’: [‘抽烟’, ‘喝酒’, ‘烫头’, ‘Massage’], ‘name’: ‘alex’}, {‘hobby_list’: [‘喊麦’, ‘街舞’], ‘name’: ‘wusir’}]

第二方法,使用 setdeafult

dic={}  # 空字典
li= []  # 空列表
for el in list3:
    dic.setdefault(el["name"],[]).append(el['hobby'])
    # 1. 如果有当前name就返回对应列表并且追加新的hobby
    # 2. 如果没有,就返回空列表,追加hobby进去
    # 字典的结果如下:
    # {'alex': ['抽烟', '喝酒', '烫头', 'Massage'], 'wusir': ['喊麦', '街舞']}


for k,v in dic.items():  # 遍历字典
    di = {}    # 将新字典清空后追加到列表,防止每次循环k,v被更新替代
    di["name"]=k  # 设置姓名
    di["hobby_list"]=v  # 设置爱好
    li.append(di)  # 最加到列表中


print(li)

执行输出,效果同上!

第 16 题有一个 bug,当输入 1 + ab 还是会打印出总和,解决方法如下:

dic = {'最终计算结果': None}

while True:
    #总和,必须要放到whlie循环里面,否则会和上次的计算结果相加
    the_sum = 0
    #标志位,必须要放到whlie循环里面,否则无法重置
    flag = True
    #切割加号两边的数字
    content = input('请输入内容:').strip()
    for i in content.split('+'):
        #去除加号2边数字的空格
        i = i.strip()
        #判断是否为数字
        if i.isdigit():
            #自增加
            the_sum += int(i)
        else:
            print("输入 {} 非法!".format(i))
            #如果包含了字母,标志为False
            flag = False
            continue

    #判断加号2边的,是否全是数字。
    if flag:
        dic['最终计算结果'] = the_sum
        print(dic)

执行效果如下:

    ![](https://cdn.nlark.com/yuque/0/2020/png/1484428/1597722036984-dcac8929-449e-40ce-be3e-ad1255e3dbd8.png)      

购物车程序,达到的效果如下:

    ![](https://cdn.nlark.com/yuque/0/2020/png/1484428/1597722037062-a46d6d68-c830-473b-b446-8fca8d7548b4.png)      

根据老师上次的代码

li = ["手机", "电脑", '鼠标垫', '游艇']
while True:
    for i in li:
        print('{}\t{}'.format(li.index(i)+1,i))
    num = input('请输入商品序号: q/Q退出:').strip()
    if num.isdigit():
        num = int(num)
        if num > 0 and num <= len(li):
            print(li[num - 1])
        else:
            print('您输入的选项,超出范围,请重新输入')
    elif num.upper() == 'Q':break
    else:
        print('输入的有非数字,请重新输入')

先修改一下执行的输出显示

goods = [
    {"name": "电脑", "price": 1999},
    {"name": "鼠标", "price": 10},
    {"name": "游艇", "price": 20},
    {"name": "美女", "price": 998},
]

while True:
    print('请选择以下商品'.center(16, '*'))
    for i in goods:
        print('{}\t{} {}'.format(goods.index(i)+1,i['name'],i['price']))
    num = input('请选择您输入的商品序号(输入Q或者q为退出):').strip()
    if num.isdigit():
        num = int(num)
        if num > 0 and num <= len(goods):
            print('您已经成功购买{}'.format(goods[num - 1]['name']))
        else:
            print('您输入的选项,超出范围,请重新输入')
    elif num.upper() == 'Q':break
    else:
        print('输入的有非数字,请重新输入')

执行输出:

    ![](https://cdn.nlark.com/yuque/0/2020/png/1484428/1597722037098-17c86b98-11c5-4c20-9238-ecb93fbfa30d.png)      

增加一个输入框,用来输入资产,在购买商品之前,判断余额是否足够,扣除资产

goods = [
    {"name": "电脑", "price": 1999},
    {"name": "鼠标", "price": 10},
    {"name": "游艇", "price": 20},
    {"name": "美女", "price": 998},
]

# 总资产
while True:
    assets = input('请输入你的总资产:').strip()
    if assets.isdigit():
        assets = int(assets)
        break
    else:
        print('您输入是非数字,请重新输入')

while True:
    print('请选择以下商品'.center(16, '*'))
    # 打印商品列表
    for i in goods:
        print('{}\t{} {}'.format(goods.index(i) + 1, i['name'], i['price']))
    num = input('请选择您输入的商品序号(输入Q或者q为退出):').strip()
    if num.isdigit():
        num = int(num)
        if num > 0 and num <= len(goods):
            # 判断当前余额是否大于商品价格
            if assets >= goods[num - 1]['price']:
                # 扣除商品价格后为当前余额
                assets -= goods[num - 1]['price']
            else:
                print('当前余额不足,无法购买此商品!')

        else:
            print('您输入的选项,超出范围,请重新输入')
    elif num.upper() == 'Q':
        break
    else:
        print('输入的有非数字,请重新输入')

执行输出:

    ![](https://cdn.nlark.com/yuque/0/2020/png/1484428/1597722037085-67752c21-5901-432f-9946-9197eb89e3a8.png)      

加入购物车列表,输入 q 之后,打印购物车列表

goods = [
    {"name": "电脑", "price": 1999},
    {"name": "鼠标", "price": 10},
    {"name": "游艇", "price": 20},
    {"name": "美女", "price": 998},
]
#购物车列表
shopping_cart = []
# 总资产
while True:
    assets = input('请输入你的总资产:').strip()
    if assets.isdigit():
        assets = int(assets)
        break
    else:
        print('您输入是非数字,请重新输入')

while True:
    print('请选择以下商品'.center(16, '*'))
    #打印商品列表
    for i in goods:
        print('{}\t{} {}'.format(goods.index(i)+1,i['name'],i['price']))
    num = input('请选择您输入的商品序号(输入Q或者q为退出):').strip()
    if num.isdigit():
        num = int(num)
        if num > 0 and num <= len(goods):
            #判断当前余额是否大于商品价格
            if assets >= goods[num - 1]['price']:
                # 扣除商品价格后为当前余额
                assets -= goods[num - 1]['price']
                # 加入购物车列表
                shopping_cart.append({'name': goods[num - 1]['name'], 'price': goods[num - 1]['price']})
                print('您已经成功购买{},您的余额是{}'.format(goods[num - 1]['name'], assets))
            else:
                print('当前余额不足,无法购买此商品!')
        else:
            print('您输入的选项,超出范围,请重新输入')
    elif num.upper() == 'Q':
        print('您已经购买了如下商品')
        for i in shopping_cart:
            print(i)
        break
    else:
        print('输入的有非数字,请重新输入')

执行输出:

    ![](https://cdn.nlark.com/yuque/0/2020/png/1484428/1597722037052-7c46f4c2-a6ca-43bb-8bcd-b1e4eb3011c3.png)      

程序: 三级菜单

要求:

  1. 打印省、市、县三级菜单

  2. 可返回上一级

  3. 可随时退出程序

先准备基础数据

zone = {
    '山东' : {
        '青岛' : ['四方','黄岛','崂山','李沧','城阳'],
        '济南' : ['历城','槐荫','高新','长青','章丘'],
        '烟台' : ['龙口','莱山','牟平','蓬莱','招远']
    },
    '江苏' : {
        '苏州' : ['沧浪','相城','平江','吴中','昆山'],
        '南京' : ['白下','秦淮','浦口','栖霞','江宁'],
        '无锡' : ['崇安','南长','北塘','锡山','江阴']
    },
    '浙江' : {
        '杭州' : ['西湖','江干','下城','上城','滨江'],
        '宁波' : ['海曙','江东','江北','镇海','余姚'],
        '温州' : ['鹿城','龙湾','乐清','瑞安','永嘉']
    }
}

以下展示的代码,不包含 zone,因为占用行数太多了。

获取省列表

print(zone.keys())

执行输出:

dict_keys([‘浙江’, ‘山东’, ‘江苏’])

输出的类型是一个特殊类型,没有索引。但是我需要获取索引,怎么办?

把数据转换为列表不就可以了吗?

#省列表
province = list(zone.keys())
print(province)

执行输出:

[‘浙江’, ‘山东’, ‘江苏’]

打印省列表,并格式化输出

#省列表
province = list(zone.keys())
#打印省列表
print('省'.center(20,'*'))
for i in province:
    print('{}\t{}'.format(province.index(i)+1,i))

执行输出:

增加一个输入框,用来输入省编号,这里需要循环输出,用 while 循环

并且判断输入的内容是否合规

#省列表
province = list(zone.keys())
#打印省列表
print('省'.center(20,'*'))
while True:
    for i in province:
        print('{}\t{}'.format(province.index(i)+1,i))
    province_input = input('请输入省编号,或输入q/Q退出:').strip()
    if province_input.isdigit():
        province_input = int(province_input)
        if province_input > 0 and province_input <= len(province):
            pass
        else:
            print('省编号 {} 不存在!'.format(province_input))
    elif province_input.upper() == 'Q':
        break
    else:
        print('输入省编号非法!')

执行输出:

    ![](https://cdn.nlark.com/yuque/0/2020/png/1484428/1597722037022-45ec0430-3d33-4e2e-bf7e-927df92ad394.png)      

进入市列表

#省列表
province = list(zone.keys())
#打印省列表
print('省'.center(20,'*'))
while True:
    for i in province:
        print('{}\t{}'.format(province.index(i)+1,i))
    province_input = input('请输入省编号,或输入q/Q退出:').strip()
    if province_input.isdigit():
        province_input = int(province_input)
        if province_input > 0 and province_input <= len(province):
            #省编号,由于显示加1,获取的时候,需要减1
            province_id = province_input - 1
            #城市列表
            city = list(zone[province[province_id]].keys())
            #进入市区列表
            while True:
                print('市'.center(20, '*'))
                for j in city:
                    print('{}\t{}'.format(city.index(j) + 1, j))
                city_input = input("请输入市编号,或输入b(back)返回上级菜单,或输入q(quit)退出:").strip()
            #退出省循环
            break
        else:
            print('省编号 {} 不存在!'.format(province_input))
    elif province_input.upper() == 'Q':
        break
    else:
        print('输入省编号非法!')

执行输出:

    ![](https://cdn.nlark.com/yuque/0/2020/png/1484428/1597722037133-6389d5e0-b081-4009-820d-b30e7753618c.png)      

判断输入的市编号是否合规

#省列表
province = list(zone.keys())
#打印省列表
print('省'.center(20,'*'))
while True:
    for i in province:
        print('{}\t{}'.format(province.index(i)+1,i))
    province_input = input('请输入省编号,或输入q/Q退出:').strip()
    if province_input.isdigit():
        province_input = int(province_input)
        if province_input > 0 and province_input <= len(province):
            #省编号,由于显示加1,获取的时候,需要减1
            province_id = province_input - 1
            #城市列表
            city = list(zone[province[province_id]].keys())
            #进入市区列表
            while True:
                print('市'.center(20, '*'))
                for j in city:
                    print('{}\t{}'.format(city.index(j) + 1, j))
                city_input = input("请输入市编号,或输入b(back)返回上级菜单,或输入q(quit)退出:").strip()
                if city_input.isdigit():
                    city_input = int(city_input)
                    if city_input > 0 and city_input <= len(city):
                        pass
                    else:
                        print('市编号 {} 不存在!'.format(city_input))
                else:
                    print('输入市编号非法!')

            #退出省循环
            break
        else:
            print('省编号 {} 不存在!'.format(province_input))
    elif province_input.upper() == 'Q':
        break
    else:
        print('输入省编号非法!')

执行输出:

    ![](https://cdn.nlark.com/yuque/0/2020/png/1484428/1597722037057-974f05f2-32c5-42ca-9ff1-8db2fc2df870.png)      

完成输入 b 返回上一级菜单功能

这里需要调整一下输出省列表的位置,删除多余的 breck。还有输入 q 退出。

#省列表
province = list(zone.keys())
while True:
    print('省'.center(20, '*'))
    # 打印省列表
    for i in province:
        print('{}\t{}'.format(province.index(i)+1,i))
    province_input = input('请输入省编号,或输入q/Q退出:').strip()
    if province_input.isdigit():
        province_input = int(province_input)
        if province_input > 0 and province_input <= len(province):
            #省编号,由于显示加1,获取的时候,需要减1
            province_id = province_input - 1
            #城市列表
            city = list(zone[province[province_id]].keys())
            #进入市区列表
            while True:
                print('市'.center(20, '*'))
                for j in city:
                    print('{}\t{}'.format(city.index(j) + 1, j))
                city_input = input("请输入市编号,或输入b(back)返回上级菜单,或输入q(quit)退出:").strip()
                if city_input.isdigit():
                    city_input = int(city_input)
                    if city_input > 0 and city_input <= len(city):
                        pass
                    else:
                        print('市编号 {} 不存在!'.format(city_input))
                elif city_input.upper() == 'B':
                    break
                elif city_input.upper() == 'Q':
                    #由于在多层while循环里面,直接exit退出即可
                    exit()
                else:
                    print('输入市编号非法!')
        else:
            print('省编号 {} 不存在!'.format(province_input))
    elif province_input.upper() == 'Q':
        break
    else:
        print('输入省编号非法!')

执行输出:

    ![](https://cdn.nlark.com/yuque/0/2020/png/1484428/1597722037034-76d9b0e4-a202-49a2-8f9b-e2d6ccf0f02b.png)      

进入县级,打印县列表,并提示输入框。这里不能再输入数字了,直接提示返回或者退出

#省列表
province = list(zone.keys())
while True:
    print('省'.center(20, '*'))
    # 打印省列表
    for i in province:
        print('{}\t{}'.format(province.index(i)+1,i))
    province_input = input('请输入省编号,或输入q/Q退出:').strip()
    if province_input.isdigit():
        province_input = int(province_input)
        if province_input > 0 and province_input <= len(province):
            #省编号,由于显示加1,获取的时候,需要减1
            province_id = province_input - 1
            #城市列表
            city = list(zone[province[province_id]].keys())
            #进入市区列表
            while True:
                print('市'.center(20, '*'))
                for j in city:
                    print('{}\t{}'.format(city.index(j) + 1, j))
                city_input = input("请输入市编号,或输入b(back)返回上级菜单,或输入q(quit)退出:").strip()
                if city_input.isdigit():
                    city_input = int(city_input)
                    if city_input > 0 and city_input <= len(city):
                        # 市编号,由于显示加1,获取的时候,需要减1
                        city_id = city_input - 1
                        #县列表
                        county = zone[province[province_id]][city[city_id]]
                        # 县列表
                        while True:
                            print('县'.center(20, '*'))
                            for k in county:
                                print('{}\t{}'.format(county.index(k) + 1, k))
                            #到县这一级,不能输入编号了,直接提示返回菜单或者退出
                            county_input = input("输入b(back)返回上级菜单,或输入q(quit)退出:").strip()
                    else:
                        print('市编号 {} 不存在!'.format(city_input))
                elif city_input.upper() == 'B':
                    break
                elif city_input.upper() == 'Q':
                    #由于在多层while循环里面,直接exit退出即可
                    exit()
                else:
                    print('输入市编号非法!')
        else:
            print('省编号 {} 不存在!'.format(province_input))
    elif province_input.upper() == 'Q':
        break
    else:
        print('输入省编号非法!')

执行输出:

    ![](https://cdn.nlark.com/yuque/0/2020/png/1484428/1597722037071-184c17d4-017d-406d-87f7-825e7873dbb6.png)      

判断县输入的内容。这里直接判断是否输入的是 b 或者 q。其他的直接提示,已经到底线了。

#省列表
province = list(zone.keys())
while True:
    print('省'.center(20, '*'))
    # 打印省列表
    for i in province:
        print('{}\t{}'.format(province.index(i)+1,i))
    province_input = input('请输入省编号,或输入q/Q退出:').strip()
    if province_input.isdigit():
        province_input = int(province_input)
        if province_input > 0 and province_input <= len(province):
            #省编号,由于显示加1,获取的时候,需要减1
            province_id = province_input - 1
            #城市列表
            city = list(zone[province[province_id]].keys())
            #进入市区列表
            while True:
                print('市'.center(20, '*'))
                for j in city:
                    print('{}\t{}'.format(city.index(j) + 1, j))
                city_input = input("请输入市编号,或输入b(back)返回上级菜单,或输入q(quit)退出:").strip()
                if city_input.isdigit():
                    city_input = int(city_input)
                    if city_input > 0 and city_input <= len(city):
                        # 市编号,由于显示加1,获取的时候,需要减1
                        city_id = city_input - 1
                        #县列表
                        county = zone[province[province_id]][city[city_id]]
                        # 县列表
                        while True:
                            print('县'.center(20, '*'))
                            for k in county:
                                print('{}\t{}'.format(county.index(k) + 1, k))
                            #到县这一级,不能输入编号了,直接提示返回菜单或者退出
                            county_input = input("输入b(back)返回上级菜单,或输入q(quit)退出:").strip()
                            if county_input == 'b':
                                # 终止此层while循环,跳转到上一层While
                                break
                            elif county_input == 'q':
                                # 结束程序
                                exit()
                            else:
                                print("已经到底线了,请返回或者退出!")
                    else:
                        print('市编号 {} 不存在!'.format(city_input))
                elif city_input.upper() == 'B':
                    break
                elif city_input.upper() == 'Q':
                    #由于在多层while循环里面,直接exit退出即可
                    exit()
                else:
                    print('输入市编号非法!')
        else:
            print('省编号 {} 不存在!'.format(province_input))
    elif province_input.upper() == 'Q':
        break
    else:
        print('输入省编号非法!')

执行输出:

    ![](https://cdn.nlark.com/yuque/0/2020/png/1484428/1597722037083-5fbdbe32-24c7-42cd-89e0-9bff66c57cb4.png)      

修改错误提示为红色字体,最终完整代码如下:

zone = {
    '山东' : {
        '青岛' : ['四方','黄岛','崂山','李沧','城阳'],
        '济南' : ['历城','槐荫','高新','长青','章丘'],
        '烟台' : ['龙口','莱山','牟平','蓬莱','招远']
    },
    '江苏' : {
        '苏州' : ['沧浪','相城','平江','吴中','昆山'],
        '南京' : ['白下','秦淮','浦口','栖霞','江宁'],
        '无锡' : ['崇安','南长','北塘','锡山','江阴']
    },
    '浙江' : {
        '杭州' : ['西湖','江干','下城','上城','滨江'],
        '宁波' : ['海曙','江东','江北','镇海','余姚'],
        '温州' : ['鹿城','龙湾','乐清','瑞安','永嘉']
    }
}
#省列表
province = list(zone.keys())
while True:
    print('省'.center(20, '*'))
    # 打印省列表
    for i in province:
        print('{}\t{}'.format(province.index(i)+1,i))
    province_input = input('请输入省编号,或输入q/Q退出:').strip()
    if province_input.isdigit():
        province_input = int(province_input)
        if province_input > 0 and province_input <= len(province):
            #省编号,由于显示加1,获取的时候,需要减1
            province_id = province_input - 1
            #城市列表
            city = list(zone[province[province_id]].keys())
            #进入市区列表
            while True:
                print('市'.center(20, '*'))
                for j in city:
                    print('{}\t{}'.format(city.index(j) + 1, j))
                city_input = input("请输入市编号,或输入b(back)返回上级菜单,或输入q(quit)退出:").strip()
                if city_input.isdigit():
                    city_input = int(city_input)
                    if city_input > 0 and city_input <= len(city):
                        # 市编号,由于显示加1,获取的时候,需要减1
                        city_id = city_input - 1
                        #县列表
                        county = zone[province[province_id]][city[city_id]]
                        # 县列表
                        while True:
                            print('县'.center(20, '*'))
                            for k in county:
                                print('{}\t{}'.format(county.index(k) + 1, k))
                            #到县这一级,不能输入编号了,直接提示返回菜单或者退出
                            county_input = input("输入b(back)返回上级菜单,或输入q(quit)退出:").strip()
                            if county_input == 'b':
                                # 终止此层while循环,跳转到上一层While
                                break
                            elif county_input == 'q':
                                # 结束程序
                                exit()
                            else:
                                print("\033[41;1m已经到底线了,请返回或者退出!\033[0m")
                    else:
                        print("\033[41;1m市编号 {} 不存在!\033[0m".format(city_input))
                elif city_input.upper() == 'B':
                    break
                elif city_input.upper() == 'Q':
                    #由于在多层while循环里面,直接exit退出即可
                    exit()
                else:
                    print("\033[41;1m输入市编号非法!\033[0m")
        else:
            print("\033[41;1m省编号 {} 不存在!\033[0m".format(province_input))
    elif province_input.upper() == 'Q':
        break
    else:
        print("\033[41;1m输入省编号非法!\033[0m")

执行输出:

    ![](https://cdn.nlark.com/yuque/0/2020/gif/1484428/1597722037027-81a1b81a-f070-432d-9b7f-74c295a12ed7.gif)