Python- - -练习目录

练习题

1,简述变量命名规范

1.必须是字母,数字,下划线的任意组合;
2.不能是数字开头;
3.不能是python中的关键字;
4.变量不能是中文;
5.变量不能过长;
6.变量要具有可描述性;

2,字节和位的关系。

8位等于1个字节

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

utf-8 (一个中文代表3个字节)    字节:2*3=6        位数:6*8=48
gbk    (一个中文代表2个字节)   字节:2*2=4         位数:4*8=32 

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

capitalize: 首字母大写其余字母小写
swapcase: 大小写翻转
title: 非字母隔开的每个单词的首字母大写
center:  设置总长度,并居中
upper():  全大写
lower(): 全小写
startswith: 检测字符串是否是由相同的开头,返回True或False
endswith: 检测字符串是否是由相同的结尾,返回True或False
strip: 默认去除字符串前后的空格,换行符,制表符
lstrip(): 默认只去除左边的空格
rstrip(): 默认只去除右边的空格
replace: 字符串替换
split:  分隔,str ---> list
join: 分割,list---> str
find: 通过元素找索引,找不到返回-1
index: 通过元素找索引,找不到会报错
len: 测量个数
count: (数)(方法统计某个元素在列表中出现的次数)
format: 格式化输出
isalnum: 检验字符串是否由字母和数字组成
isalpha: 检测字符串是否只由字母组成
isdigit: 检测字符串是否只由数字组成
sort(): 正序排序列表中的元素
sort(): 倒叙排序列表中的元素
reverse(): 翻转列表中的元素

5,Python中的常量是什么?如何表示?通常放在文件的哪里?

用全部大写的字符串表示,通常放在文件的开头。

6,Python中的单行注释和多行注释分别是什么?

单行注释 #  和多行注释 '''   '''

7,Python中input输入的是什么数据类型?

字符串。

8,书写Python2与python3中的三个不同。

python2X: 源码不规范,源码混乱,重复代码多。
python3X: 重整源码,源码规范,优美,清晰,简单
python2x: 默认的编码方式ascii,
显示中文:首行:  # -*- edcoding:utf-8 -*-
python3x: 默认的编码方式 utf - 8
python2x: print '内容'  或者 print('内容')
python3x: print('内容')
print () 打印内容用小括号括起来
raw_input 与 input 合并为input
print语句被python3废弃,统一使用print函数
exec语句被python3废弃,统一使用exec函数
execfile语句被Python3废弃,推荐使用exec(open("./filename").read())
不相等操作符"<>"被Python3废弃,统一使用"!="
long整数类型被Python3废弃,统一使用int
python2X: 源码不规范,源码混乱,重复代码多。

9,写代码,有如下列表,利用切片实现每一个功能。

l1 = ['a', 'b', 'c', 'WuSir', 'TaiBai', '老男孩']

1)通过对li列表的切片形成新的列表l2,l2 = [‘a’,’c’,'TaiBai']
l2=l1[::2]

2)通过对li列表的切片形成新的列表l3,l3 = [‘a’,’WuSir’]
l3=l1[::3]
print(l3,type(l3))

3)通过对li列表的切片形成新的列表l4,l4 = [‘老男孩’]?
del l1[:-1]
print(l1)

4)通过对li列表的切片形成新的列表l5,l5 = ['TaiBai', 'c','a']
l5=l1[-2::-2]
print(l5)

10,组合嵌套题。

a,写代码,有如下列表,按照要求实现每一个功能

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

1)将列表lis中的’tt’变成大写(用两种方式)。
lis[0][3]['k1'][0]='TT'
lis[0][3]['k1'][0]=lis[0][3]['k1'][0].upper()
print(lis)
2)将列表中的数字3变成字符串’100’(用两种方式)。 lis[0][3]['k1'][1]='100' lis[0][3]['k1'][1]=str(lis[0][3]['k1'][1]+97) print(lis)
3)将列表中的字符串’1’变成数字101(用两种方式)。 lis[0][3]['k1'][2]=101 lis[0][3]['k1'][2]=int(lis[0][3]['k1'][2]+'01') lis[0][3]['k1'][2]=int(lis[0][3]['k1'][2])+100 print(lis)
b,写代码,有如下字典,按照要求实现每一个功能
dic = {'k1': 'v1','k2': ['alex','sb'],(1,2,3,): {'k3': ['2', 100, 'TaiBai']}}
1)将’k2’对应的值的最后面的’sb’删除。
dic['k2'].remove('sb')#同一个字典内部通过键去找字典的内容,列表是索引
print(dic)
2)将’k2’对应的值的第二个位置插入一个元素 ’老男孩’。 dic['k2'].insert(1,'老男孩') print(dic)
3)将(1,2,3,)对应的值添加一个键值对(1,2,3),’ok’。 dic[(1,2,3,)]['(1,2,3)']='ok' print(dic) 4)将’k3’对应的列表的最后追加’a’,’b’,’c’,’d’四个元素。 dic[(1,2,3,)]['k3'].extend('abcd') print(dic)
5)将'TaiBai'改成男神。 dic[(1,2,3,)]['k3'][2]='男神' print(dic)

11,转化题。

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

int可以转换为str
str可以转换为int 条件是str内容全部为整数
Int 与 bool之间如何转化,转换的结果是什么?有没有条件?
int-->bool 0是False,其他是True
bool-->int True是1  False是0
str 与 bool之间如何转化,转换的结果是什么?有没有条件?
str -->bool 空字符串是False,其他是True
bool --> str True是1  False是0
str 与 list 能否转化?如何转化?
能,用split()

12,实现下列结果。

1)有列表li = ['老男孩', 'alex', 'WuSir', 'TaiBai']
通过一行代码构造一个字符串s=’老男孩**alex**WuSir**TaiBai’
li = ['老男孩', 'alex', 'WuSir', 'TaiBai']
'**'.join(li)
print('**'.join(li))
2)有字符串s ='alex WuSir TaiBai',通过一行代码构造一个列表li = [ 'alex', 'WuSir', 'TaiBai'] s ='alex WuSir TaiBai' li=s.split() print(li)
3)有字符串s = ‘alex’通过操作该字符串构造一个字符串s1 = ‘a_l_e_x’ s = 'alex' s1 ='_'.join(s) print(s1)

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

for循环

sum=0
for i in range(100):
    if i % 2 == 1:
        sum+=i
    else:
        sum-=i
print(sum)
while循环
"""
给start赋值为1,sum赋值为0,当start的赋值小于100的时候while循环为真
temp的赋值等于start和2的余数,如果temp的赋值等于1,sum的赋值就等于
sum加start的赋值(余数为1,start就是奇数),否则sum的赋值就等于sum减start的
赋值(余数不为1就为0,start就是偶数),start重新赋值
等于start加1,一直加到start的赋值等于99,while循环为假!打印sum
"""

start = 1
sum = 0
while start <100:
    temp = start % 2
    if temp ==1:
        sum = sum + start
    else:
        sum = sum - start
    #print(start)
    #sum = sum + 1
    start += 1
print(sum)

14.使用range打印100,98,96,94....6,4,2,0

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

15,有如下列表:li = ['老男孩', 'WuSir', 'alex', 'TaiBai'],写代码,通过代码构造成一个新列表l2

l2= ['老男孩SB', 'WuSirNB', 'alexSB', 'TaiBaiNB']

li = ['老男孩', 'WuSir', 'alex', 'TaiBai']
l2=[]
for i in li:
    if li.index(i) % 2 == 1:
        i=i+'NB'
    else:
        i=i+'SB'
    l2.append(i)
print(l2)

anser
li = ['老男孩', 'WuSir', 'alex', 'TaiBai']
for index in range(len(li)):
    # print(index)
    if index % 2 == 0:
        li[index] = li[index] +'SB'
    else:
        li[index] = li[index] + 'NB'
print(li)

16,编写程序,统计如下各个字符串个数。

如有此字符串str1 = "hello world god is allways busy",最后得到的结果为:‘h:1,e:1,l:5,o:3,w:2,r:1,d:2,g:1,i:1,s:3,a:2,y:2,b:1,u:1,’

anser
str1 = "hello world god is allways busy"
# l1=str1.split()
# print(l1)
# s=''.join(l1)
# print(s)

s1 = ''.join(str1.split())  # ["hello","world"......]
print(s1)  # helloworldgodisallwaysbusy
result = ""
for i in s1:
    if i not in result:
        result = result + i + ':' + str(s1.count(i)) + ','  # '' + h + : + 1 + ,#字符串的相加
                # 'h:1,' + e + : + 1 + ,
print(result)

17,元素分类

 

将一个列表的元素,分类后分别放到两个列表中
  有如下值集合 [11,22,33,44,55,66,77,88,99,90],将所有大于 66 的值保存至一个列表,小于等于66的值保存到另一个列表
#!/usr/bin/env python
# -*- coding:utf-8 -*-
print("将一个列表的元素,分类后分别放到两个列表中")
a = [11,22,33,44,55,66,77,88,99,90]
b = [] #创建空列表b
c = [] #创建空列表c
for i in a: #循环a列表元素
    if i <= 66:
        b.append(i) #判断循环到的元素小于或等于66的,追加到b列表
    else:
        c.append(i) #判断循环到的元素大于66的,追加到c列表
#分别打印出b列表和c列表
print(b)
print(c)
#打印出
#[11, 22, 33, 44, 55, 66]
#[77, 88, 99, 90]

 

将一个列表的元素,分类后分别放到一个字典中,列1
  有如下值集合 [11,22,33,44,55,66,77,88,99,90],将所有大于 66 的值保存至字典的k1键值,小于等于66的值保存至字典的k2键值。
#!/usr/bin/env python
# -*- coding:utf-8 -*-
print("将一个列表的元素,分类后分别放到一个字典中,列1")
a = [11,22,33,44,55,66,77,88,99,90]
b = [] #创建空列表b
c = [] #创建空列表c
for i in a: #循环a列表元素
    if i <= 66:
        b.append(i) #判断循环到的元素小于或等于66的,追加到b列表
    else:
        c.append(i) #判断循环到的元素大于66的,追加到c列表
d = {"k1":b, "k2":c} #新创建一个字典,键为k1和k2,把b列表赋值给k1键,把c列表赋值给k2键
print(d)#打印出d字典
#打印出 {'k2': [77, 88, 99, 90], 'k1': [11, 22, 33, 44, 55, 66]}
将一个列表的元素,分类后分别放到一个字典中,列2
  有如下值集合 [11,22,33,44,55,66,77,88,99,90],将所有大于 66 的值保存至字典的k1键值,小于等于66的值保存至字典的k2键值。
#!/usr/bin/env python
# -*- coding:utf-8 -*-
print("将一个列表的元素,分类后分别放到一个字典中,列2")
a = [11,22,33,44,55,66,77,88,99,90]
b = {"k1":[], "k2":[]}
for i in a: #循环a列表元素
    if i <= 66:
        b["k1"].append(i) #判断循环到的元素小于或等于66的,追加到b列表
    else:
        b["k2"].append(i) #判断循环到的元素大于66的,追加到c列表
print(b)
#打印出 {'k2': [77, 88, 99, 90], 'k1': [11, 22, 33, 44, 55, 66]}

18,元素查找

 查找列表,元组,字典,中元素,移除每个元素的空格,并查找以 a或A开头 并且以 c 结尾的所有元素。

  li = ["alec", " aric", "Alex", "Tony", "rain"]
    tu = ("alec", " aric", "Alex", "Tony", "rain") 
    dic = {'k1': "alex", 'k2': ' aric',  "k3": "Alex", "k4": "Tony"}
1,查找列表中元素,移除每个元素的空格,并查找以 a或A开头 并且以 c 结尾的所有元素。
  li = ["alec", " aric", "Alex", "Tony", "rain"]
#!/usr/bin/env python
# -*- coding:utf-8 -*-
print("查找列表中元素,移除每个元素的空格,并查找以 a或A开头 并且以 c 结尾的所有元素。")
li = ["aleb", " aric", "Alex", "Tony", "rain"]
for i in li:
    b = i.strip() #移除循环到数据的两边空格
    #判断b变量里以a或者A开头,并且以c结尾的元素
    #注意:如果一个条件语句里,or(或者),and(并且),都在条件判断里,将前面or部分用括号包起来,当做一个整体,
    #不然判断到前面or部分符合了条件,就不会判断and后面的了,括起来后不管前面符不符合条件,后面的and都要判断的
    if (b.startswith("a") or b.startswith("A")) and b.endswith("c"):
        print(b) #打印出判断到的元素
#打印出
#aric
2,查找元组中元素,移除每个元素的空格,并查找以 a或A开头 并且以 c 结尾的所有元素。
  tu = ("aleb", " aric", "Alex", "Tony", "rain")
#!/usr/bin/env python
# -*- coding:utf-8 -*-
print("查找元组中元素,移除每个元素的空格,并查找以 a或A开头 并且以 c 结尾的所有元素。")
tu = ("aleb", " aric", "Alex", "Tony", "rain")
for i in tu:
    tu1 = i.strip() #移除循环到数据的两边空格
    #判断tu1变量里以a或者A开头,并且以c结尾的元素
    #注意:如果一个条件语句里,or(或者),and(并且),都在条件判断里,将前面or部分用括号包起来,当做一个整体,
    #不然判断到前面or部分符合了条件,就不会判断and后面的了,括起来后不管前面符不符合条件,后面的and都要判断的
    if (tu1.startswith("a") or tu1.startswith("A")) and tu1.endswith("c"):
        print(tu1) #打印出判断到的元素
#打印出
#aric
3,查找字典中元素,移除每个元素的空格,并查找以 a或A开头 并且以 c 结尾的所有元素。
  dic = {'k1': "alex", 'k2': ' aric',  "k3": "Alex", "k4": "Tony"}
print("查找字典中元素,移除每个元素的空格,并查找以 a或A开头 并且以 c 结尾的所有元素。")
dic = {'k1': "aleb", 'k2': ' aric',  "k3": "Alex", "k4": "Tony"}
for i in dic:
    dic1 = dic[i].strip() #移除循环到数据的两边空格
    #判断dic1变量里以a或者A开头,并且以c结尾的元素
    #注意:如果一个条件语句里,or(或者),and(并且),都在条件判断里,将前面or部分用括号包起来,当做一个整体,
    #不然判断到前面or部分符合了条件,就不会判断and后面的了,括起来后不管前面符不符合条件,后面的and都要判断的
    if (dic1.startswith("a") or dic1.startswith("A")) and dic1.endswith("c"):
        print(dic1) #打印出判断到的元素
#打印出
#aric

19,实现一个整数加法计算器:

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

con = content.split('+')
sum = 0
for i in con:
    i=i.strip()
    i=int(i)
    sum=sum+i
print(sum)

anser
dic={‘最终计算结果’:None}。
content = input('输入内容:').strip()
li = content.split('+')
dic = {'最终结果': None}
sum = 0
for i in li:
    sum += int(i)
dic['最终结果'] = sum
print(dic)

20,按要求完成下列转化(如果给list3再添加多个类似的字典如{"name": "太白", "hobby": "sport"})。

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": ["喊麦", "街舞"]},

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

list4=[]
for i in list3:
    for j in list4:
        if i['name']==j['name']:
            j['hobby_list'].append(i['hobby'],)
            break
        else:
            list4.append({'name':i['name'],'hobby_list':i['hobby']},)

print(list4)

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

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

'''
dic = {
'alex': {"name": "alex", "hobby_list": ["抽烟"]},
    'wusir':{"name": "wusir", "hobby_list": ["喊麦", "街舞"]},
}
print(list(dic.values()))
方法一
dic = {}
for i in list3:
    if i['name'] not in dic:
        dic[i['name']] = {'name':i['name'],'hobby_list':[i['hobby'],]}
    else:
        dic[i['name']]["hobby_list"].append(i['hobby'])
print(list(dic.values()))
list4 = [
    {"name": "alex", "hobby_list": ["抽烟", "喝酒", "烫头", "Massage"]},
    {"name": "wusir", "hobby_list": ["喊麦", "街舞"]},
]

list4 = []
#list4 = [{"name": "alex", "hobby_list": ["抽烟", ]]
for i in list3:
    # {"name": "alex", "hobby": "抽烟"},
    # {"name": "alex", "hobby": "喝酒"},
    for j in list4:    # list4 = [{"name": "alex", "hobby_list": ["抽烟", ]}]
        #  j = {"name": "alex", "hobby_list": ["抽烟", ]}
        if i['name'] == j['name']:
            j['hobby_list'].append(i['hobby'],)
            break
    else:
        list4.append({'name':i['name'],'hobby_list':[i['hobby'],]})
print(list4)

21,写程序,模拟公司HR将员工信息录入公司内部系统。

录入的员工信息表为这种数据类型:
user_list = [
{'id':1,
'personal_info':
{'name':'老男孩',
'age':56,
'sex':'男',
'marry_status':'是',
'edu_background':'本科'}
}
]
1,HR选择添加员工信息或者退出。
2,分别将员工的姓名,年龄,性别,婚否,学历这几项依次录入员工信息表中,其中id为自增(id不用HR填写,而是每添加一个员工信息就自动加1,并且id是唯一的)。
3,如果遇到录入员工信息时有相同的姓名,那么就将相同的姓名的员工的名字变成 名字+id(如之前录入了一个名叫张三的员工,之后新员工又有同名的情况也叫张三,那么后面这个张三名字要改成 张三2(此id为他的对应的id))。
4,退出整个程序时,最后要将本次录入的所有的员工姓名依次打印出来。
Ps:

user_list = [
    {'id':1,
     'personal_info':
         {'name':'老男孩',
          'age':56,
          'sex':'男',
          'marry_status':'是',
          'edu_background':'本科'}
     },
             ]
l1 = [{'name':'alex'}, 22, 33]
print(len(l1))
while True:
    choice = input('是否添加员工信息/Q或q退出:').strip()
    if choice.upper() == 'Q':break
    name, age, sex, marry_status, edu_background = input('请依次输入姓名,年龄,性别,婚否,学历').strip().replace(',', ',').split(',')
    # msg_list = ['太白', '21', '男', '已婚', '本科']
    for i in user_list:
        if name == i['personal_info']['name']:
            name = name + str(len(user_list) + 1)
    user_list.append(
        {'id': len(user_list) + 1,
         'personal_info':
             {'name': name,
              'age': age,
              'sex': sex,
              'marry_status': marry_status,
              'edu_background': edu_background}
         }
    )



s1 = '太白,21,男,已婚,本科'
s2 = s1.replace(',',',')
print(s2.split(','))

for i in user_list[1:]:
    print(i['personal_info']['name'])
 

转载于:https://www.cnblogs.com/bingo1024/p/9081344.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值