'''
2.写函数,检查获取传入列表或元组对象的所有奇数位
索引对应的元素,并将其作为新列表返回给调用者。
'''
#学会了 原来 range(len(iter)) 是 从零到len-1 的数的组合 建新放在函数里就可以
#学会了 原来 range(len(iter))  是 从零到len-1 的数的组合  建新放在函数里就可以
def hanshu1(can1):
new_line1 = []
for i in range(1,len(can1),2):
new_line1.append(can1[i])
return new_line1
lis1 = [1,9,3,4,5,6,7]
tup1 = (1,9,3,4,5,6,7)
ret1 = hanshu1(lis1)
print(ret1)
ret2 = hanshu1(tup1)
print(ret2) #以下两者相同 都是0-4 顾头不顾尾
# for a in range(5):
# print(a,end=' ')
# for a in range(0,5):
# print(a,end=' ')
#3 3.写函数,判断用户传入的对象(字符串、列表、元组)长度是否大于5。
# 学到了 不是写 print 而是写 return 而且把 返回的值 print即可
def hanshu2(can2):
if len(can2)>5:
return '大于5!'
else:
return '不大于5!'
i1 = [1,2,3]
i2 = ''
i3 = (1,2,'',[])
print(len(i2))
print(hanshu2(i1))
print(hanshu2(i2))
print(hanshu2(i3))
'''
4.写函数,检查传入列表的长度,如果大于2,
那么仅保留前两个长度的内容,并将新内容返回给调用者。
'''#是不是只执行一个 return 只要第一个return 有了值 就不走下一个了 是!
def hanshu3(can3):
new_list1 = []
if len(can3)>2:
for i in range(2):
new_list1.append(can3[i])
else:
return can3
return new_list1
print(hanshu3([5]))
#写函数,检查传入list, str ,tuple的长度,如果大于2,
def hanshu3(can3):
if len(can3)>2:
a = can3[0:2]
else:
return can3
return a
print(hanshu3((1,2,3)))
'''
5.写函数,计算传入函数的字符串中,
[数字]、[字母]、[空格] 以及 [其他]的个数,并返回结果。'''
def hanshu4(can4):
st = 0
zim = 0
kongg = 0
qit = 0
for can in can4:
if can.isdigit():
st += 1
elif can.isalpha():
zim +=1
elif can==' ':
kongg +=1
else:
qit +=1
return st,zim,kongg,qit
shu,zi,kong,qi = hanshu4('adada_ 11%%%')
print('数字:{},字母:{},空格:{},其它:{}'.format(shu,zi,kong,qi))
print(hanshu4('adada_ 11%%%'))
#6.写函数,接收两个数字参数,返回比较大的那个数字。
def hanshu5(can51, can52):
return can51 if can51 > can52 else can52
print(hanshu5(1,1))
'''
7.写函数,检查传入字典的每一个value的长度,如果大于2,
那么仅保留前两个长度的内容,并将新内容返回给调用者。
dic = {"k1": "v1v1", "k2": [11,22,33,44]}
PS:字典中的value只能是字符串或列表
'''
#学会了 用列表存值 然后用
# for rang() 删后面的方法 都是用的这些
# 因为 对字典进行操作 所以 都输出can6
def hanshu6(can6):
if len(can6)>2:
lis = []
for key in can6:
lis.append(key)
for i in range(2,len(can6)):
print(i)
del can6[lis[i]]
else:
return can6
return can6
dic = {"k1": "v1v1",'k3':1, "k2": [11,22,33,44] }
print(hanshu6(dic))
读题读错了 是改值 的内容 两位 改之
dic = {"k1": "v1v1", "k2": [11,22,33,44]}
def hanshu7(can7):
for a in can7:
if len(can7[a])>2: can7[a] = can7[a][0:2]
return can7
print(hanshu7(dic))

'''
8.写函数,此函数只接收一个参数且此参数必须是列表数据类型,
此函数完成的功能是返回给调用者一个字典,此字典的键值对为此列表的索引及对应的元素。
例如传入的列表为:[11,22,33] 返回的字典为 {0:11,1:22,2:33}。'''
def hanshu7(can7):
i = 0
dic1 = {}
for list2 in can7:
dic1[i] =list2
i += 1
return dic1
print(hanshu7([11,22,33]))''
'''
9.写函数,函数接收四个参数分别是:
姓名,性别,年龄,学历。用户通过输入这四个内容,
然后将这四个内容传入到函数中,此函数接收到这四个内容,
将内容追加到一个student_msg文件中。'''
def hanshu8(can81, can82,can83,can84):
with open('student_msg','a',encoding='utf-8') as f:
f.write(can81)
f.write(can82)
f.write(str(can83))
f.write(can84)
name,gender,age,education = 'liuyang','男',25,'本科'
print(name,gender,age,education)
hanshu8(name,gender,age,education)
'''
# 10.对第9题升级:支持用户持续输入,Q或者q退出,
# 性别默认为男,如果遇到女学生,则把性别输入女。'''
# # def hanshu8(can81, can82, can83='男' , can84): # 默认的不能再待赋前
# 因为 把后面的 改成 strip() 浪费了诸多时间 打印出来就好了
# 就是一个赋值 的问题 因为 split(',')从中作梗,耽误了,
# 付给他值然后split(‘,’)格式就可以了
'''
def hanshu8(can81, can83,can84,can82='男'):
with open('student_msg', 'a', encoding='utf-8') as f:
f.write(can81)
f.write(str(can83))
f.write(can84)
f.write(can82)
while 1 :
# name, gender, age, education = 'liuyang', '男', 25, '本科'
# a = input('输入你的内容:')
list3 = input('name,age,education,gender:(输入q\Q退出)')
if list3.lower() =='q':
break
else:
list2 = list3.split(',')
print(list2)
name, age, education,gender = list2
print(name, age, education,gender)
hanshu8(name, age, education,gender)
'''
11. 写函数,用户传入修改的文件名,
与要修改的内容,执行函数,完成整个文件的批量修改操作(升级题)。''' #肯定得先新建文件

用r+

def hanshu9(file_name , old_ele,new_ele):
# with open(file_name)as read_f,open(file_name,'w')as write_f:
with open(file_name,"r+")as read_f:
a=read_f.read().replace(old_ele, new_ele)
# read_f.seek(0,0)
read_f.write(a)
read_f.truncate()#如果比原有的短。自动覆盖 如果比原有的等长没事
hanshu9('genggai','dalaoa','laoshi')

用删一个 赋值的方法

def hanshu9(file_name , old_ele,new_ele,old_name):
with open(file_name)as read_f , open(old_name,'w')as write_f:
write_f.write(read_f.read().replace(old_ele, new_ele))
os.remove(file_name)
os.rename(file_name,old_name)
hanshu9('genggai','dalaoa','laoshi','a')

day08作业---函数的更多相关文章

  1. 网络1911、1912 C语言第4次作业--函数批改总结

    目录 网络1911.1912 C语言第4次作业--函数批改总结 一.评分规则 二.本次作业亮点 三.本次作业存在的问题 四.助教有话说 五.得分详情 网络1911.1912 C语言第4次作业--函数批 ...

  2. C语言第十一次作业--函数嵌套调用

    一.实验作业 1.1 PTA题目:递归法对任意10个数据按降序排序 设计思路 定义整型循环变量i,最小值下标min,中间变量t 若n==1,直接返回 否则 min=10-n 最小值下标赋初值 for ...

  3. C语言第五次博客作业--函数

    一.PTA实验作业 题目1:使用函数判断完全平方数 1. 本题PTA提交列表 2. 设计思路 3.本题调试过程碰到问题及PTA提交列表情况说明. 部分正确 :将else的情况放入for循环内,导致循环 ...

  4. C语言博客作业--函数嵌套调用

    一.实验作业(6分) 本周作业要求: 选一题PTA题目介绍. 学习工程文件应用,设计实现学生成绩管理系统. 学生成绩管理系统要求 设计一个菜单驱动的学生成绩管理程序,管理n个学生m门考试科目成绩,实现 ...

  5. C语言博客作业—函数嵌套调用

    一.实验作业 1.1 PTA题目:递归法对任意10个数据按降序排序 1.1.1设计思路 void sort(int a[],int n) { 定义整型循环变量i,中间变量temp,最小值min: 令m ...

  6. C语言第十一次博客作业---函数嵌套调用

    一.实验作业 1.1 PTA题目 题目:递归实现顺序输出整数 1. 本题PTA提交列表 2. 设计思路 printdigits函数 定义整型变量result存放结果 if n是10的倍数 result ...

  7. C语言博客作业--函数

    一.PTA实验作业 题目1 (6-7) (1).本题PTA提交列表 (2)设计思路 设计第一个函数判断是否完数int factorsum( int number ) 定义sum.i:sum初始化归0, ...

  8. C语言第五次作业函数

    一.PTA实验作业 题目1: 6-6 使用函数输出水仙花数 1.本题PTA提交列表 2.设计思路 1.narcissistic函数 1.由于number的值后面会变化,所以定义d,e用于储存numbe ...

  9. C语言博客作业——函数

    一.PTA实验作业 题目1:6-6 使用函数输出水仙花数 1.本题PTA提交列表 2. 设计思路 int narcissistic( int number ) //函数定义 1.定义整数型变量a.i分 ...

随机推荐

  1. mysql 5.7.21 主从集群恢复GTID方式(不锁库)

    从库损坏后,进行恢复 1.查看主加标记点 show master status\G 记录下POST的值 2.备注主库数据 mysqldump -u root -p -S /data/mysql/mys ...

  2. manipulate

    manipulate - 必应词典 美[mə'nɪpjə.leɪt]英[mə'nɪpjʊleɪt] v.控制:摆布:(有技巧地)使用:巧妙地处理(问题等) 网络操纵:被操纵:被控体 变形第三人称单数: ...

  3. Jmeter cookie不兼容问题

    历史脚本,今天准备执行测试,报出这种错误 解决方案:HTTP Cookie Manager里的 Cookie Policy 由rfc2109设置为兼容模式(Compatibility) 参考:http ...

  4. HDU 1542 Atlantis(线段树面积并)

     描述 There are several ancient Greek texts that contain descriptions of the fabled island Atlantis. S ...

  5. Django的restframework的序列化组件之对单条数据的处理

    之前我们学习的都是处理书籍或者出版社的所有的数据的方法,下面我们来看下处理单个书籍,或者单个出版社的方法 这个时候我们就需要重新写一个类,这个类的方法,就需要有3个参数,参数1是self,参数2是re ...

  6. 微信公众号开发(5)---使用开源组件开发公众号OAuth2.0网页授权授权登录

    搞清微信公众号授权登录的步骤步骤,我们的开发就完成了一大步 献上github 地址: https://github.com/Wechat-Group/weixin-java-tools/wiki/MP ...

  7. day 16 包,random,shutil

    包: 函数过多,可以分模块文件去管理函数,模块文件过多,将模块文件分类放在一个个的文件夹中,这个文件夹就叫做包,组织结构更加清晰,合理! 模式就是被别人使用,包既然是一些模块的集合,也是被调用. 文件 ...

  8. Android Studio连接真机调试

    1.安装配置Android studio2.2 2.下载手机驱动或者安装手机助手(360手机助手) 3.用手机助手连接用于调试的手机 注意手机要开启开发者模式->允许USB调试 4.查看手机连接 ...

  9. Java使用点滴

    1.查找某个字符在字符串中第几次出现的位置 /** * 查找某个字符在字符串中第几次出现的位置 * @param string 要匹配的字符串 * @param i 第几次出现 * @param ch ...

  10. linux下安装以及升级npm,node的方法

    1.最开始使用阿里云文档提供的安装方法一直都是失败的状态,后来找到了新的方法重新安装,按照以下操作一步一步的走即可实现,亲测可用 2.安装完之后,会发现npm和node的版本都偏低,需要重新升级以下, ...