第2章 Python基础-字符编码&数据类型 列表&元祖 练习题
1.创建一个空列表,命名为names,往里面添加old_driver,rain,jack,shanshan,peiqi,black_girl元素
names = ["old_driver","rain","jack","shanshan","peiqi","black_girl"]
print(names)
2.往names列表里black_girl前面插入一个alex
names.insert(names.index("black_girl"),"alex")
print(names)
3.把shanshan的名字改成中文,姗姗
names[names.index("shanshan")] = "姗姗"
print(names)
4.往names列表里rain的后面插入一个子列表,["oldboy","oldgirl"]
names.insert(names.index("rain")+1,["oldboy","oldgirl"])
print(names)
5.返回peiqi的索引值
print(names.index("peiqi"))
6.创建新列表[1,2,3,4,2,5,6,2],合并入names列表
names.extend([1,2,3,4,2,5,6,2])
print(names)
7.取出names列表中索引4-7的元素
print(names[4:7])
8.取出names列表中索引2-10的元素,步长为2
print(names[2:10:2])
9.取出names列表中最后3个元素
print(names[-3:])
10.循环names列表,打印每个元素的索引值,和元素
#枚举
for index,name in enumerate(names):
print("%s. %s" % (index,name))
#计数
index = 0
for name in names:
print("%s. %s" % (index, name))
index += 1
11.循环names列表,打印每个元素的索引值,和元素,当索引值为偶数时,把对应的元素改为-1
for index,name in enumerate(names):
if index % 2 == 0:
names[index] = -1
print(names)
12.names里有3个2,请返回第2个2的索引值。不要人肉数,要动态找(提示,找到第一个2的位置,在次基础上再找第2个)
print(names.index(2,names.index(2)+1))
13.查找列表(或元祖或字典)中元素,移除每个元素的空格,并查找以 a 或 A 开头 并且以 c 结尾的所有元素
li = ["alec", " aric", "Alex", "Tony", "rain"]
tu = ("alec", " aric", "Alex", "Tony", "rain")
dic = {'k1': "alex", 'k2': ' aric',"k3": "Alex", "k4": "Tony"}
#!/usr/bin/env python
# -*- coding:utf-8 -*- li = ["alec", " aric", "Alex", "Tony", "rain"] for S in li:
S = S.strip()
prefix_a = S.startswith('a')
prefix_A = S.startswith('A')
suffix_c = S.endswith('c')
if prefix_a or prefix_A and suffix_c:
print('要查找的元素:%s' % S) tu = ("alec", " aric", "Alex", "Tony", "rain") for S in tu:
S = S.strip()
prefix_a = S.startswith('a')
prefix_A = S.startswith('A')
suffix_c = S.endswith('c')
if prefix_a or prefix_A and suffix_c:
print('要查找的元素:%s' % S) dic = {'k1': "alex", 'k2': ' aric',"k3": "Alex", "k4": "Tony"} for S in dic.values():
S = S.strip()
prefix_a = S.startswith('a')
prefix_A = S.startswith('A')
suffix_c = S.endswith('c')
if prefix_a or prefix_A and suffix_c:
print('要查找的元素:%s' % S)
14.写代码,有如下列表,按照要求实现每一个功能
li = ['alex','eric','rain']
- 计算列表长度并输出
li = ['alex','eric','rain']
v = len(li)
print(v)
- 列表中追加元素 “seven”,并输出添加后的列表
li = ['alex','eric','rain']
li.append('seven')
print(li)
- 请在列表的第 1 个位置插入元素 “Tony”,并输出添加后的列表
li = ['alex','eric','rain']
li.insert(0,'Tony')
print(li)
- 请修改列表第 2 个位置的元素为 “Kelly”,并输出修改后的列表
li = ['alex','eric','rain']
li[1] = 'Kelly'
print(li)
- 请删除列表中的元素 “eric”,并输出修改后的列表
li = ['alex','eric','rain']
li.remove('eric')
print(li)
- 请删除列表中的第 2 个元素,并输出删除的元素的值和删除元素后的列表
li = ['alex','eric','rain']
v = li.pop(1)
print(v,li)
- 请删除列表中的第 3 个元素,并输出删除元素后的列表
li = ['alex','eric','rain']
li.pop(2)
print(li)
- 请删除列表中的第 2 至 4 个元素,并输出删除元素后的列表
li = ['alex','eric','rain','rain','rain']
del li[1:4]
print(li)
- 请将列表所有的元素反转,并输出反转后的列表
li = ['alex','eric','rain']
li.reverse()
print(li)
- 请使用 for、len、range 输出列表的索引
li = ['alex','eric','rain']
for i in range(len(li)):
print(i)
- 请使用 enumrate 输出列表元素和序号(序号从 100 开始)
li = ['alex','eric','rain']
for i,v in enumerate(li,100):
print(i,v)
- 请使用 for 循环输出列表的所有元素
li = ['alex','eric','rain']
for i in li:
print(i)
15.写代码,有如下列表,请按照功能要求实现每一个功能
li = ["hello", 'seven', ["mon", ["h", "kelly"], 'all'], 123, 446]
请根据索引输出“Kelly”
#!/usr/bin/python
# -*- coding:utf-8 -*- li = ["hello", 'seven', ["mon", ["h", "kelly"], 'all'], 123, 446]
print(li[2][1][1])
请使用索引找到'all'元素并将其修改为“ALL”,如:li[0][1][9]...
#!/usr/bin/python
# -*- coding:utf-8 -*- li = ["hello", 'seven', ["mon", ["h", "kelly"], 'all'], 123, 446]
li[2][2] = "ALL"
print(li)
16.写代码,有如下元祖,请按照功能要求实现每一个功能
tu = ('alex','eric','rain')
- 计算元组长度并输出
tu = ('alex','eric','rain')
v = len(tu)
print(v)
- 获取元组的第 2 个元素,并输出
tu = ('alex','eric','rain')
v = tu[1]
print(v)
- 获取元组的第 1‐2 个元素,并输出
tu = ('alex','eric','rain')
v = tu[0:2]
print(v)
- 请使用 for 输出元组的元素
tu = ('alex','eric','rain')
for i in tu:
print(i)
- 请使用 for、len、range 输出元组的索引
for i in range(len(tu)):
print(i)
- 请使用 enumrate 输出元祖元素和序号(序号从 10 开始)
tu = ('alex','eric','rain')
for i,v in enumerate(tu,10):
print(i,v)
17.有如下变量,请实现要求的功能
tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11,22,33)}, 44])
- 讲述元祖的特性
元组的一级元素不可被修改增加删除,有序,可迭代,可切片,可索引,可转换为列表。
- 请问 tu 变量中的第一个元素 “alex” 是否可被修改?
不可被修改
- 请问 tu 变量中的"k2"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素 “Seven”
tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11,22,33)}, 44])
v = tu[1][2]["k2"]
v.append("Seven")
print(tu)
- 请问 tu 变量中的"k3"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素 “Seven”
k3对应的是元组,不可修改
18.现有商品列表如下:
products = [ ['iphone8',6888], ['MacPro', 14800], ['小米6',2499], ['coffee',31],['book',80],['Nike shoes',799]]
请打印出这样的格式: -----------商品信息 ------------
0. iphone8 6888
1. MacPro 14800
2. 小米6 2499
3. coffee 31
4. book 80
5. Nike shoes 799
products = [ ['iphone8',6888], ['MacPro', 14800], ['小米6',2499], ['coffee',31],['book',80],['Nike shoes',799]]
print("商品信息".center(28,"-"))
for index,product in enumerate(products):
print("%s.%s %s" %(index,product[0],product[1]))
# print("{0}.{1} {2}".format(index,product[0],product[1]))
19.利用上题中的列表,写一个循环,不断的问用户想买什么,用户选择一个商品标号,就把对应的商品添加到购物车里,最终用户输入q退出时,打印购物车里的商品列表。
products = [ ['iphone8',6888], ['MacPro', 14800], ['小米6',2499], ['coffee',31],['book',80],['Nike shoes',799]] shopping_cart = [] # 定义一个空的购物车 exit_flag = False # while True:
while not exit_flag:
print("商品信息".center(28, "-"))
for index,product in enumerate(products):
print("%s. %s %d" % (index,product[0],product[1])) product_choice = input("\n请输入商品标号:\n")
if product_choice.isdigit(): #判断输入的字符串是否只包含数字
product_choice = int(product_choice) # 字符串转成整型
if product_choice >= 0 and product_choice < len(products):
shopping_cart.append(products[product_choice][0]) #增加到购物车列表
print("\n商品 %s 已添加到购物车\n" % (products[product_choice][0]))
else:
print("商品标号有误,请重新输入")
elif product_choice == "q":
if len(shopping_cart) > 0:
print("\n您添加到购物车的商品如下:\n")
for index,product_cart in enumerate(shopping_cart):
print("%s. %s" % (index,product_cart))
else:
print("\n您的购物车为空!\n")
# break
exit_flag = True #为真时候结束循环
第2章 Python基础-字符编码&数据类型 列表&元祖 练习题的更多相关文章
- 第2章 Python基础-字符编码&数据类型 字符编码&字符串 练习题
1.简述位.字节的关系 位(bit)是计算机中最小的表示单元,数据传输是以“位”为单位的,1bit缩写为1b 字节(Byte)是计算机中最小的存储单位,1Byte缩写为1B 8bit = 1Byte ...
- 第2章 Python基础-字符编码&数据类型 综合 练习题
1.转换 将字符串s = "alex"转换成列表 s = "alex" s_list = list(s) print(s_list) 将字符串s = " ...
- 第2章 Python基础-字符编码&数据类型 购物车&多级菜单 作业
作业 一.三级菜单 数据结构: menu = { '北京':{ '海淀':{ '五道口':{ 'soho':{}, '网易':{}, 'google':{} }, '中关村':{ '爱奇艺':{}, ...
- 第2章 Python基础-字符编码&数据类型 字典 练习题
1.写代码,有如下字典,按照要求实现每一个功能,dic = {'k1':'v1','k2':'v2','k3':[11,22,33]} 请循环输出所有的 key dic = {'k1':'v1','k ...
- Python基础-字符编码与转码
***了解计算机的底层原理*** Python全栈开发之Python基础-字符编码与转码 需知: 1.在python2默认编码是ASCII, python3里默认是utf-8 2.unicode 分为 ...
- python学习第八讲,python中的数据类型,列表,元祖,字典,之字典使用与介绍
目录 python学习第八讲,python中的数据类型,列表,元祖,字典,之字典使用与介绍.md 一丶字典 1.字典的定义 2.字典的使用. 3.字典的常用方法. python学习第八讲,python ...
- python学习第七讲,python中的数据类型,列表,元祖,字典,之元祖使用与介绍
目录 python学习第七讲,python中的数据类型,列表,元祖,字典,之元祖使用与介绍 一丶元祖 1.元祖简介 2.元祖变量的定义 3.元祖变量的常用操作. 4.元祖的遍历 5.元祖的应用场景 p ...
- python学习第六讲,python中的数据类型,列表,元祖,字典,之列表使用与介绍
目录 python学习第六讲,python中的数据类型,列表,元祖,字典,之列表使用与介绍. 二丶列表,其它语言称为数组 1.列表的定义,以及语法 2.列表的使用,以及常用方法. 3.列表的常用操作 ...
- Python学习day4 数据类型Ⅱ(列表,元祖)
day4 知识补充&数据类型:列表,元祖 1.知识补充 1.编译型/解释型 编译型:在代码编写完成之后编译器将其变成另外一个文件教给你算计执行. 代表语言:Java,c,c++ ,c#, Go ...
随机推荐
- vSphere Replication:虚拟机的保护伞
http://server.zdnet.com.cn/server/2013/0401/2151318.shtml ZDNet至顶网服务器频道 04月01日 新闻消息: 保护IT环境的一个基本方面就是 ...
- VB数组的清除
在一个程序中,同一数组只能用Dim语句定义一次.但有时可能需要清除数组的内容或对数组重新定义,这可以用:Erase语句来实现. 格式:Erase(数组名)[,(数组名)] 功能:用于重新初始化静态数组 ...
- time series review
https://pdfs.semanticscholar.org/fc9c/1a94a15dd44c8c61b3e4841ecb9505f8cd37.pdf https://edoc.hu-berli ...
- python之tcp自动重连
操作系统: CentOS 6.9_x64 python语言版本: 2.7.13 问题描述 现有一个tcp客户端程序,需定期从服务器取数据,但由于种种原因(网络不稳定等)需要自动重连. 测试服务器示例代 ...
- dubbo应用架构演进路线图
1.单应用单服务器: 2.单应用拆分成多个应用并部署到多个服务器: 3.单应用拆分成多个应用并实现分布式部署: 4.流动计算框架(用于提高机器利用率的资源调度和治理中心).
- python3新特点
#xiaodeng #python 3 #1.编码方式和性能 ''' 1.py3运行效率更快 2.默认源文件编码ASCII变为UTF-8,以前文件前加入的coding=utf-8不再需要 3.针对un ...
- Java 安装和变量环境配置
//1.分别安装sdk和jre,需要2个均安装才是完整的 //1)jdk_8u60_windows_i586_V8.0.600.27.1440040557 //2)jre_8u60_windows_i ...
- Spring Cloud Zuul性能调整
Spring Cloud 版本: Dalston.SR5 这两天通过JMeter测了一下Spring Cloud Zuul的性能,用的是两台虚机8核8G和4核8G,宿主机是10核逻辑20核,代理的服务 ...
- word2vec训练中文模型
-- 这篇文章是一个学习.分析的博客 --- 1.准备数据与预处理 首先需要一份比较大的中文语料数据,可以考虑中文的维基百科(也可以试试搜狗的新闻语料库).中文维基百科的打包文件地址为 https: ...
- Q值, 电感Q因素, 电感品质因素, Inductor Q, Quality Factor
Q值基本概念 Q值, 品质因素, Quality Factor 是广泛使用于物理和工程领域的一个参数, 这指的是一个机械或非机械的组件里, 共振(谐振)的能量损失比例, 是衡量一个元件或谐振回路性能的 ...