整理了31道python3基础练习题
1、 执行 Python 脚本的两种方式
1)/usr/bin/python3 xx.py
2)python3 xx.py #注xx.py需要在内容里面调用由什么解释器执行
2、 简述位、字节的关系
1Byte = 8bit
1bit 表示某个二进制 0 1
3、 简述 ascii、unicode、utf-8、gbk 的关系
最初计算机是由美国发明的,计算机需要一套相应的字符编码集ascii,来表示英文字符后来中国也表示也用来计算机,也需要一套字符编码集来表示汉字字符,也就是gbk由于各国需要用计算机都需要一套相应的字符编码,来表示自已国家的字符,于是就出现统一的字符编码的集也就是unicode,所有的字符都表示两个字节,原来英文字符只占用一个字节,存放英文字符文档,会浪费一倍的空间,美国肯定不会同意于是就出现了utf-8编码,可变长的字符编码,英文字符编码表示1个字节,汉字表示3个字节这下美国就开兴了哈!
4、 请写出 “你好” 分别用 utf-8 和 gbk 编码所占的位数
你好 在utf-8中一个中文字符3个字节(Byte) 1字节 = 8位(bit) 你好就在utf-8表示24位
你好 在gbk中一个中文字符用2个字节(Byte) 1字节 = 8位(bit) 你好就在gbk中表示16位
5、 Pyhton 单行注释和多行注释分别用什么?
单行注释:用 #注释内容
多行注释:用'''注释内容''' 或者 """注释内容"""
6、 声明变量注意事项有那些?
1 变量名不能以数字开头
2 变量名只能是数字,下划线,英文字母的组合
3 变量名不能有特殊符号
4 某些特定的字符不能用做变量名
7、 如何查看变量在内存中的地址?
id(变量名)
8、 执行 Python 程序时,自动生成的 .pyc文件的作用是什么?
当执行xx.py的python会 把编译的结果会保存在位于内存中的Pycodeobject中,python程序运行结束,python解释器则将PyCodeObject写回到pyc文件中。
当python再次执行xx.py时,首先程序会在硬盘中寻找pyc文件,直接载入,否则就重复上面的过程.pyc文件在_pycache_
注:自已理解,我也不是很了解
9、写代码
a.实现用户输入用户名和密码,当用户名为seven且密码为123时,显示登陆成功,否则登陆失败!
代码如下:
#Python学习交流群:778463939
user = "seven"
passwd = 123
username = input("please the enter user:")
password = int(input("please the enter passwd:"))
if username == user and password == passwd:
print("logon successfull")
else:
print("logon failed")
注意:input()输入的任何内容都是字符串
b.实现用户输入用户名和密码,当用户名为 seven且密码为 123 时,显示登陆成功,否则登陆失败,失败时允许重复输入三次
代码如下
user = "seven"
passwd = 123
for i in range(3):
username = input("please the enter user:")
password = input("please the enter passwd:")
if password.isdigit():
password = int(password)
if username == user and passwd == password:
print("logon successfull")
break
else:
print("logon failed")
else:
print("logon failed")
c.实现用户输入用户名和密码,当用户名为 seven 或 alex 且密码为 123 时,显示登陆成功,否则登陆失败,失败时允许重复输入三次
代码如下:
user = ["seven","alex"]
passwd = 123
for i in range(3):
username = input("please the enter user:")
password = input("please the enter passwd:")
if password.isdigit():
password = int(password)
if (username in user) and passwd == password:
print("logon successfull")
break
else:
print("logon failed")
else:
print("logon failed")
10、写代码
a.使用 while 循环实现输出 2-3+4-5+6 ...+100
的和
代码如下:
even = 0
count = 1
while count<100:
count+=1
#方法1:得出偶数-奇数+偶数-奇数...
#方法2:求出所有的偶数减去所有的奇数和 (跟小学的换位运算类似)
if count % 2 == 0:
print("2-100的偶数",count)
even += count
else:
print("2-100的奇数",count)
even -= count
print(even) #得出的结果
b.使用 for 循环和 range 实现输出1-2+3-4+5-6....-98+99
的和
代码如下:
#Python学习交流群:778463939
uneven = 0
for i in range(1,100):
#方法1:得出的奇数-偶数+奇数-偶数....
#方法2:求出奇数和,求出偶数和,用奇数和减偶数和
if i % 2 == 1:
print("1-99的奇数",i)
uneven += i
else:
print("1-99的偶数",i)
uneven -= i
print(uneven) #得出结果
c.使用 while 循环实现输出1,2,3,4,5,7,8,9,11,12
代码如下:
count = 0
while count <12:
count += 1
if count == 6:
continue
elif count ==10:
continue
print(count)
d.使用 while 循环实现输出 1-100 内的所有奇数
代码如下:
count = 0
while count < 100:
count += 1
if count % 2 == 1:
print("1-100的奇数",count)
e. 使用 while 循环实现输出1-100内的所有偶数
代码如下:
count = 0
while count < 100:
count += 1
if count % 2 == 0:
print("1-100的偶数",count)
11、分别书写数字5,10,32,7的二进制表示
在python解释器中执行bin(number),把某个数字转换成二进制
二进制的表示:0b (binary)
bin(5) #0b101
bin(10) #0b1010
bin(32) #0b100000
bin(7) #0b111
12、简述对象和 类的关系(可用比喻的手法)
类:用来描述具有相同属性和方法的对象集合,它定义每个对象的属性所共有的属性和方法,对象是类的实例
对象:通过类定义的数据结构实例
假如:人是一个种类,我们自已本身就是类的对象
类是一张图纸(该图纸上画了建筑的模型,以及怎样实现),实际高楼大夏就是图纸
实现的对象,类是抽象的,对象是实际存在的。
13、现有如下两个变量,请简述 n1 和 n2是什么关系?
n1=123
n2=123
n1和n2关系是一样 ,我们可以用id(n1),id(n2)在内存中的地址的表示
14、现有如下两个变量,请简述 n1 和 n2是什么关系?
n1 = 123456
n2 = 123456
n1和n2虽然在值是一样的,在内存地址表示中是不一样的
注:
(在python内部中,内存还有一个(小数字池,字符串池)缓存池,对于经常用的,在python内部编译有一个优化,在这个缓存池,如果重复使用,都是使用同一内存缓存池的内存(地址)空间
如果大于这个缓存池,则会在内存独立开辟新的一个内存(地址)空间
例如
数字的缓存池 -5 至 256 可以用不相同的变量名,相同的值,用id(变量名),看它们的内存地址)
15、现有如下两个变量,请简述 n1 和 n2 是什么关系?
n1 = 123456
n2 = n1
n2 是 n1 值的引用 它们在内存的地址是一样和内容也是一样的,只是不同命名变量的赋值:
赋值不会开辟新的内存空间,它只是复制了新对象的引用,如果n1的值发生改变,n2还是原来的改变之前值
16、如有一下变量 n1 =5,请使用 int 的提供的方法,得到该变量最少可以用多少个二进制位表示?
n1= 5
print(n1.bit_length())
#结果
3
17、布尔值分别有什么?
True False
18、阅读代码,请写出执行结果
a = "alex"
b = a.capitalize()
print(a)
print(b)
请写出输出结果:
alex #a
Alex #b
19、写代码,有如下变量,请按照要求实现每个功能
name = " aleX"
a. 移除 name 变量对应的值两边的空格,并输入移除有的内容
print(name.strip())
#结果
aleX
b.判断 name 变量对应的值是否以 "al" 开头,并输出结果
print(name.startswith("al"))
#结果
False
c.判断 name 变量对应的值是否以 "X" 结尾,并输出结果
print(name.endswith("X"))
#结果
True
d.将 name 变量对应的值中的 “ l” 替换为 “ p”,并输出结果
print(name.replace("l","p"))
#结果
apeX
e.将 name 变量对应的值根据 “ l” 分割,并输出结果。
print(name.split("l"))
#结果
['\ta', 'eX'] #\t 表示使用了tab
f.请问,上一题 e分割之后得到值是什么类型?
print(type(name.split("l")))
#结果
<class 'list'> #列表
g.将 name 变量对应的值变大写,并输出结果
print(name.upper())
ALEX
h.将 name 变量对应的值变小写,并输出结果
print(name.lower())
#结果
alex
i.请输出 name 变量对应的值的第 2 个字符?
print(name[2])
#结果
l
j. 请输出 name 变量对应的值的前 3 个字符?
print(name[:3])
#结果
al
k. 请输出 name 变量对应的值的后 2 个字符?
print(name[-2:])
#结果
eX
l.请输出 name 变量对应的值中 “ e” 所在索引位置?
print(name.index('e'))
#结果
3
20、字符串是否可迭代?如可以请使用 for 循环每一个元素?
字符串可以迭代
代码如下:
#Python学习交流群:778463939
hobby = "一条龙"
for i in hobby:
print(i)
显示结果如下:
一
条
龙
21、请用代码实现:利用下划线将列表的每一个元素拼接成字符串,li = ['alex', 'eric', 'rain']
print("_".join(li))
#结果
alex_eric_rain
22、写代码,有如下列表,按照要求实现每一个功能
li = ['alex','eric','rain']
a.计算列表长度并输出
print(len(li))
#结果
3
b.列表中追加元素 “seven”,并输出添加后的列表
li.append("seven")
print(li)
#结果
['alex', 'eric', 'rain', 'seven']
c.请在列表的第1个位置插入元素 “Tony”,并输出添加后的列表
li.insert(0,"Tony")
print(li)
#结果
['Tony', 'alex', 'eric', 'rain']
d.请修改列表第2个位置的元素为 “Kelly”,并输出修改后的列表
li[1] = "Kelly"
print(li)
#结果
['alex', 'Kelly', 'rain']
e.请删除列表中的元素 “eric”,并输出修改后的列表
第一种:得出“eric”索引,通过索引来删除该值
第二种:直接删除"eric"
1)
del li[1];print(li) #结果['alex', 'rain']
li.pop(1);print(li) #结果['alex', 'rain']
li.remove("eric")
print(li)
#结果
['alex', 'rain']
f.请删除列表中的第2个元素,并输出删除的元素的值和删除元素后的列表
#Python学习交流群:778463939
print(li.pop(1));print(li)
#结果
eric
['alex', 'rain']
g.请删除列表中的第3个元素,并输出删除元素后的列表
print(li.pop(2));print(li)
#结果
rain
['alex', 'eric']
h.请删除列表中的第2至4个元素并输出删除元素后的列表
del li[1:3]
print(li)
#结果
['alex']
i.请将列表所有的元素反转,并输出反转后的列表
li.reverse()
print(li)
#结果
['rain', 'eric', 'alex']
j.请使用 for、len、range 输出列表的索引
#3种方法,建议用第三种
1)for
for i in li:
#list.index()列表有相同元素的,只是的获取(相同元素中的第一个元素)的索引
print(li.index(i),i) #如果列表内有相同的元素,不建议使用此方法
#结果
0 alex
1 eric
2 rain
2)len
zero = []
for i in li:
print(len(zero),i)
zero.append(i)
#结果
0 alex
1 eric
2 rain
3)range
#Python学习交流群:778463939
for i in range(len(li)):
print(i,li[i])
#结果
0 alex
1 eric
2 rain
k.请使用 enumrate 输出列表元素和序号(序号从 100 开始)
for index,i in enumerate(li,start=100):
print(index,i)
#结果
100 alex
101 eric
102 rain
l.请使用 for 循环输出列表的所有元素
for i in li:
print(i)
#结果
alex
eric
rain
23、写代码,有如下列表,请按照功能要求实现每一个功能
li=["hello",'seven',["mon",["h","kelly"],'all'],123,446]
a. 请输出 “Kelly”
print(li[2][1][1])
#结果
kelly
b.请使用索引找到 'all'元素并将其修改为 “ALL”
li[2][2] = "ALL"
print(li)
#结果
['hello', 'seven', ['mon', ['h', 'kelly'], 'ALL'], 123, 446]
24、写代码,有如下元组,按照要求实现每一个功能
tu=('alex','eric','rain')
a.计算元组长度并输出
print(len(tu))
#结果
3
b.获取元组的第2个元素,并输出
print(tu[1])
#结果
eric
c.获取元组的第 1-2个元素,并输出
print(tu[0:2])
#结果
('alex', 'eric')
d.请使用 for 输出元组的元素
for i in tu:
print(i)
#结果
alex
eric
rain
e.请使用 for、len、range 输出元组的索引
#跟22题j列表用法类似
for i in range(len(tu)):
print(i,tu[i])
#结果
0 alex
1 eric
2 rain
f.请使用 enumrate 输出元祖元素和序号(序号从 10 开始)
for index,i in enumerate(tu,start=10):
print(index,i)
#结果
10 alex
11 eric
12 rain
25、有如下变量,请实现要求的功能
tu=("alex",[11,22,{"k1":'v1',"k2":["age","name"],"k3":(11,22,33)},44])
a.讲述元祖的特性
元祖和列表类似都是有序的从0开始
不同的是元祖的元素是不能修改的
b.请问 tu 变量中的第一个元素 “alex” 是否可被修改?
不能修改
c.请问tu变量中的"k2"对应的值是什么类型?是否可以被修改?
如果可以,请在其中添加一个元素 “Seven”
print(type(tu[1][2]["k2"]))
#结果
<class 'list'>
列表类型可以修改
tu[1][2]["k2"].append("seven")
print(tu)
#结果
('alex', [11, 22, {'k2': ['age', 'name', 'seven'], 'k3': (11, 22, 33), 'k1': 'v1'}, 44])
注:表面上看,tuple的元素确实变了,但其实变的不是tuple的元素,而是list的元素。
tuple一开始指向的list并没有改成别的list,所以,tuple所谓的“不变”是说,tuple的每个元素,指向永远不变。但指向的这个list本身是可变的!
d.请问 tu 变量中的"k3"对应的值是什么类型?是否可以被修改?
如果可以,请在其中添加一个元素 “Seven”
print(type(tu[1][2]["k3"]))
#结果
<class 'tuple'>
#对应值是元祖,不能修改
26、字典
dic ={'k1':"v1","k2":"v2","k3":[11,22,33]}
a.请循环输出所有的 key
for i in dic:
print(i)
#结果
k1
k3
k2
注:字典是无序的
b.请循环输出所有的value
for i in dic:
print(dic[i])
#结果
[11, 22, 33]
v2
v1
c.请循环输出所有的 key 和 value
for i in dic:
print(i,dic[i])
#结果
k2 v2
k3 [11, 22, 33]
k1 v1
d.请在字典中添加一个键值对,"k4":"v4",输出添加后的字典
dic["k4"] = "v4"
print(dic)
#结果
{'k4': 'v4', 'k2': 'v2', 'k3': [11, 22, 33], 'k1': 'v1'}
e.请在修改字典中 “k1” 对应的值为 “alex”,输出修改后的字典
dic['k1'] = "alex"
print(dic)
#结果
{'k3': [11, 22, 33], 'k1': 'alex', 'k2': 'v2'}
f.请在 k3 对应的值中追加一个元素44,输出修改后的字典
dic["k3"].append(44)
print(dic)
#结果
{'k2': 'v2', 'k3': [11, 22, 33, 44], 'k1': 'v1'}
g.请在 k3 对应的值的第1个位置插入个元素18,输出修改后的字典
dic["k3"].insert(0,18)
print(dic)
#结果
{'k1': 'v1', 'k2': 'v2', 'k3': [18, 11, 22, 33]}
27、转换
a.将字符串 s="alex" 转换成列表
print(list(s))
#结果
['a', 'l', 'e', 'x']
b.将字符串 s="alex" 转换成元祖
print(tuple(s))
#结果
('a', 'l', 'e', 'x')
c.将列表 li =["alex","seven"]
转换成元组
print(tuple(li))
#结果
('alex', 'seven')
d.将元祖 tu =('Alex',"seven")
转换成列表
print(list(tu))
#结果
['Alex', 'seven']
e.将列表 li=["alex","seven"]
转换成字典且字典的key按照10开始向后递增
#Python学习交流群:778463939
dic1 = {}
for key,value in enumerate(li,start=10):
dic1[key] = value
print(dic1)
#结果
{10: 'alex', 11: 'seven'}
28、转码
n="老男孩"
a.将字符串转换成 utf-8 编码的字节,并输出,然后将该字节再转换成 utf-8 编码字符串,再输出
print(n.encode("utf-8"))
#结果
b'\xe8\x80\x81\xe7\x94\xb7\xe5\xad\xa9'
print(n.encode("utf-8").decode("utf-8"))
#结果
老男孩
b.将字符串转换成 gbk 编码的字节,并输出,然后将该字节再转换成 gbk 编码字符串,再输出
print(n.encode("gbk"))
#结果
b'\xc0\xcf\xc4\xd0\xba\xa2'
print(n.encode("gbk").decode("gbk"))
#结果
老男孩
29、求1-100内的所有数的和
3种方法
print(sum(range(1,101)))
#结果
5050
SUM = 0
for i in range(1,101):
SUM += i
print(SUM)
#结果
5050
SUM = 0
count = 1
while count <= 100:
SUM += count
count += 1
print(SUM)
#结果
5050
30、元素分类
有如下值集合 [11,22,33,44,55,66,77,88,99,90]
,将所有大于66的值保存至字典的第一个 key中,将小于66的值保存至第二个 key 的值中。
即:{'k1':大于 66 的所有值,'k2':小于66 的所有值}
dic = {"k1":[],
"k2":[]}
aa = set([11,22,33,44,55,66,77,88,99,90])
for i in aa:
if i>= 66:
dic["k1"].append(i)
else:
dic["k2"].append(i)
print(dic)
结果
{'k1': [66, 99, 77, 88, 90], 'k2': [33, 11, 44, 22, 55]}
31、购物车
功能要求:
要求用户输入总资产,例如: 2000
显示商品列表,让用户根据序号选择商品,加入购物车
购买,如果商品总额大于总资产,提示账户余额不足,否则,购买成功。
goods = [
{"name":"电脑","price":1999},
{"name":"鼠标","price":10},
{"name":"游艇","price":20},
{"name":"美女","price":98},
]
shop_cart = []
goods = [
{"name":"电脑","price":1999},
{"name":"鼠标","price":10},
{"name":"游艇","price":20},
{"name":"美女","price":98},
]
while True:
salary = input("请输入用户余额[quit]:")
if salary.isdigit():
salary = int(salary)
break
elif salary == "quit":
exit("不想购买")
else:
print("please the enter number")
while True:
print("shop list".center(50, '*'))
for index,i in enumerate(goods):
print(index,i)
choose_number = input("请输入购买商品编号[quit]:")
if choose_number.isdigit():
choose_number = int(choose_number)
product_list = []
if 0 <= choose_number <= len(goods):
product_list.append(goods[choose_number])
if salary >= product_list[0]["price"]:
shop_cart.append(goods[choose_number])
salary -= product_list[0]['price']
print("当前购买的商品",product_list,"当前用户余额\033[1;31m{salary}\033[0m".format(salary=salary))
else:
print("余额不足")
else:
print("无效的商品编号")
elif choose_number.lower() == 'quit':
print("购买的商品".center(50,"*"))
for y in shop_cart:
print(y)
exit()
else:
print("无效的输入")
#注:简易的购物车,还能继续优化