目录
5、编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串
8、写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母
9、写一个自己的endswith函数,判断一个字符串是否已指定的字符串结束
10、写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串
11、 写一个自己的upper函数,将一个字符串中所有的小写字母变成大写字母
12、写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充
13、 写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1
15、写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在
16、写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串
17、写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值
18、写四个函数,分别实现求两个列表的交集、并集、差集、补集的功能
1、编写函数,求1+2+3+…N的和
def sum(n):
s = 0
for i in range(n + 1):
s +=i
return s
if __name__ == '__main__':
n = int(input('请输入累加求和的数:'))
print(sum(n))
2、编写一个函数,求多个数中的最大值
#编写一个函数,求多个数中的最大值
def max(a):
max = 0
for i in range(len(n)):
if (max < n[i]):
max = n[i]
return max
if __name__ == '__main__':
n = [12,32,455,78,34,56,988,2390]
print('最大值为:{}' .format(max(n)))
3、编写一个函数,实现摇骰子的功能,打印N个骰子的点数和
#写一个函数实现摇色子的功能,传入色子的个数,返回所有色子的点数总和
import random
def sum(n):
s = 0
for i in range(n):
s +=random.randint(1,6)
return s
if __name__ == '__main__':
n = int(input('请输入骰子个数'))
print('骰子点数是:{}' .format(sum(n)))
4、编写一个函数,交换指定字典的key和value
#编写一个函数,交换指定字典的key和value。
def exchange(x):
mydict_new = {}
for key, val in mydict.items():#items获取所有的键值对,先取出来的为关键字,后取出来的为键值
mydict_new[val] = key#赋值给新的字典,字典是内部用的是hash表存储,是无序的,查找时是通过key查找value所在的位置
return mydict_new
if __name__ == '__main__':
mydict = {'张三':23,'李四':33,'王五':44}
print(exchange(mydict))
"""
字典的基本用法:
对于初学者而言,应牢记字典包含多个 key-value 对,而 key 是字典的关键数据,因此程序对字典的操作都是基于 key 的。基本操作如下:
通过 key 访问 value 。
通过 key 添加 key-value 对。
通过 key 删除 key-value 对。
通过 key 修改 key-value 对。
通过 key 判断指定 key-value 对是否存在。
通过 key 访问 value 使用的也是方括号语法,就像前面介绍的列表和元组一样,只是此时在方括号中放的是 key,而不是列表或元组中的索引。
字典特点:
字典中所有元素都是一个key-value对,key不允许重复,value可以重复
字典中的元素是无序的 —— —— ——没有下标,取值通过方法获取
字典是可变的,字典中key必须是不可变对象 —— —— ——增删改查
字典也可以根据需要动态地伸缩
字典会浪费较大的内存,是一种 以空间换时间的数据结构
字典常用方法:
clear()方法:
clear() 用于清空字典中所有的 key-value 对,对一个字典执行 clear() 方法之后,该字典就会变成一个空字典
代码如下:
cars = {'BMW': 8.5, 'BENS': 8.3, 'AUDI': 7.9}
print(cars) # {'BMW': 8.5, 'BENS': 8.3, 'AUDI': 7.9}
# 清空cars所有key-value对
cars.clear()
print(cars) # {}
get()方法:
get() 方法其实就是根据 key 来获取 value,它相当于方括号语法的增强版,当使用方括号语法访问并不存在的 key 时,字典会引发 KeyError 错误;
但如果使用 get() 方法访问不存在的 key,该方法会简单地返回 None,不会导致错误
代码如下:
cars = {'BMW': 8.5, 'BENS': 8.3, 'AUDI': 7.9}
# 获取'BMW'对应的value
print(cars.get('BMW')) # 8.5
print(cars.get('PORSCHE')) # None
print(cars['PORSCHE']) # KeyError
update()方法:
update() 方法可使用一个字典所包含的 key-value 对来更新己有的字典。在执行 update() 方法时,
如果被更新的字典中己包含对应的 key-value 对,那么原 value 会被覆盖;如果被更新的字典中不包含对应的 key-value 对,则该 key-value 对被添加进去。
代码如下:
cars = {'BMW': 8.5, 'BENS': 8.3, 'AUDI': 7.9}
cars.update({'BMW':4.5, 'PORSCHE': 9.3})
print(cars)
从上面的执行过程可以看出,由于被更新的 dict 中己包含 key 为“BMW”的 key-value 对,因此更新时该 key-value 对的 value 将被改写;
但如果被更新的 dict 中不包含 key 为“PORSCHE”的 key-value 对,那么更新时就会为原字典增加一个 key-value 对。
items()、keys()、values()方法:
items()、keys()、values() 分别用于获取字典中的所有 key-value 对、所有 key、所有 value。
这三个方法依次返回 dict_items、dict_keys 和 dict_values 对象,Python 不希望用户直接操作这几个方法,但可通过 list() 函数把它们转换成列表。
代码如下:
cars = {'BMW': 8.5, 'BENS': 8.3, 'AUDI': 7.9}
# 获取字典所有的key-value对,返回一个dict_items对象
ims = cars.items()
print(type(ims)) # <class 'dict_items'>
# 将dict_items转换成列表
print(list(ims)) # [('BMW', 8.5), ('BENS', 8.3), ('AUDI', 7.9)]
# 访问第2个key-value对
print(list(ims)[1]) # ('BENS', 8.3)
# 获取字典所有的key,返回一个dict_keys对象
kys = cars.keys()
print(type(kys)) # <class 'dict_keys'>
# 将dict_keys转换成列表
print(list(kys)) # ['BMW', 'BENS', 'AUDI']
# 访问第2个key
print(list(kys)[1]) # 'BENS'
# 获取字典所有的value,返回一个dict_values对象
vals = cars.values()
# 将dict_values转换成列表
print(type(vals)) # [8.5, 8.3, 7.9]
# 访问第2个value
print(list(vals)[1]) # 8.3
从上面代码可以看出,程序调用字典的 items()、keys()、values() 方法之后,都需要调用 list() 函数将它们转换为列表,这样即可把这三个方法的返回值转换为列表。
pop方法:
pop() 方法用于获取指定 key 对应的 value,并删除这个 key-value 对。
代码如下:
cars = {'BMW': 8.5, 'BENS': 8.3, 'AUDI': 7.9}
print(cars.pop('AUDI')) # 7.9
print(cars) # {'BMW': 8.5, 'BENS': 8.3}
popitem()方法:
popitem() 方法用于随机弹出字典中的一个 key-value 对。
此处的随机其实是假的,正如列表的 pop() 方法总是弹出列表中最后一个元素,
实际上字典的 popitem() 其实也是弹出字典中最后一个 key-value 对。
由于字典存储 key-value 对的顺序是不可知的,因此开发者感觉字典的 popitem() 方法是“随机”弹出的,
但实际上字典的 popitem() 方法总是弹出底层存储的最后一个 key-value 对。
代码如下:
cars = {'AUDI': 7.9, 'BENS': 8.3, 'BMW': 8.5}
print(cars)
# 弹出字典底层存储的最后一个key-value对,弹出也就是相当于删除了,再输出原字典时,最后一个key-vaule已经没有了
print(cars.popitem()) # ('AUDI', 7.9)
print(cars) # {'BMW': 8.5, 'BENS': 8.3}
setdefault()方法:
setdefault() 方法也用于根据 key 来获取对应 value 的值。但该方法有一个额外的功能,
即当程序要获取的 key 在字典中不存在时,该方法会先为这个不存在的 key 设置一个默认的 value,然后再返回该 key 对应的 value。
总之,setdefault() 方法总能返回指定 key 对应的 value;如果该 key-value 对存在,则直接返回该 key 对应的 value;
如果该 key-value 对不存在,则先为该 key 设置默认的 value,然后再返回该 key 对应的 value。
代码如下:
cars = {'BMW': 8.5, 'BENS': 8.3, 'AUDI': 7.9}
# 设置默认值,该key在dict中不存在,新增key-value对
print(cars.setdefault('PORSCHE', 9.2)) # 9.2
print(cars)
# 设置默认值,该key在dict中存在,不会修改dict内容
print(cars.setdefault('BMW', 3.4)) # 8.5
print(cars)
fromkeys()方法:
fromkeys() 方法使用给定的多个 key 创建字典,这些 key 对应的 value 默认都是 None;
也可以额外传入一个参数作为默认的 value。该方法一般不会使用字典对象调用(没什么意义),通常会使用 dict 类直接调用。
代码如下:
# 使用列表创建包含2个key的字典
a_dict = dict.fromkeys(['a', 'b'])
print(a_dict) # {'a': None, 'b': None}
# 使用元组创建包含2个key的字典
b_dict = dict.fromkeys((13, 17))
print(b_dict) # {13: None, 17: None}
# 使用元组创建包含2个key的字典,指定默认的value
c_dict = dict.fromkeys((13, 17), 'good')
print(c_dict) # {13: 'good', 17: 'good'}
使用字典格式化字符串
在格式化字符串时,如果要格式化的字符串模板中包含多个变量,后面就需要按顺序给出多个变量,这种方式对于字符串模板中包含少量变量的情形是合适的,
但如果字符串模板中包含大量变量,这种按顺序提供变量的方式则有些不合适。可改为在字符串模板中按 key 指定变量,然后通过字典为字符串模板中的 key 设置值。
代码如下:
# 字符串模板中使用key
temp = '教程是:%(name)s, 价格是:%(price)010.2f, 出版社是:%(publish)s'
book = {'name':'Python基础教程', 'price': 99, 'publish': 'C语言中文网'}
# 使用字典为字符串模板中的key传入值
print(temp % book)
book = {'name':'C语言小白变怪兽', 'price':159, 'publish': 'C语言中文网'}
# 使用字典为字符串模板中的key传入值
print(temp % book)
"""
5、编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串
#编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串
def extract(s):
a = []
for i in range(len(s)):
if (( 'a' < s[i] < 'z') or ( 'A'< s[i] < 'Z')):
a.append(s[i])
new = ''.join(a)
return new
if __name__ == '__main__':
s = '234236sdvskjdhk: dsjkfh'
print(extract(s))
6、写一个函数,求多个数的平均值
#写一个函数,求多个数的平均值
#
# def avg(*args):#因为不知道传入多少个值,所以用*arges代替,意思是可变的位置参数想,结果是一个元组
# s = sum(args[0])#sum() 方法对序列进行求和计算 包括:列表、元组、集合
# #因为传入的是个列表,但是又变成了元组,即成了元组里面包含一个字典了,而需要的数据是元组的第一个位置的列表
# print(s)
# avg = s / (len(args[0]))
#
# return avg
def avg(l):
return (sum(l) / len(l))
if __name__ == '__main__':
l = []
n = int(input('请输入要计算的个数:'))
for i in range(n):
k = int(input("请输入数值: "))
l.append(k)
print(avg(l))
7、写一个函数,默认求10的阶乘,也可以求其他数字的阶乘
#写一个函数,默认求10的阶乘,也可以求其他数字的阶乘
def Factorial(n):
s = 1
for i in range(1,n + 1):
s *= i
return s
if __name__ == '__main__':
n = int(input('请输入要求的阶乘'))
print(Factorial(n))
8、写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母
例如: 'abc' -> 'Abc' '12asd' --> '12asd'
#写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母
def capitalize(s):
a = []
count = 0
for i in range(len(s)):
if ( 'a' < s[i] < 'z'):
count +=1
if (count <= 1):
a.append(chr(ord(s[i]) - 32))
continue
a.append(s[i])
t = ''.join(a)
return a
if __name__ == '__main__':
s = '8576sdfhkj'
print(capitalize(s))
9、写一个自己的endswith函数,判断一个字符串是否已指定的字符串结束
例如: 字符串1:'abc231ab' 字符串2:'ab' 函数结果为: True
字符串1:'abc231ab' 字符串2:'ab1' 函数结果为: False
#写一个自己的endswith函数,判断一个字符串是否已指定的字符串结束
def end(s,y):
if (s[len(s) - len(y) ::1] == y[::]):
return True
else:
return False
if __name__ == '__main__':
s = 'aysgduihfjasjhfa'
y = 'asjhfa'
print(end(s,y))
10、写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串
例如: '1234921' 结果: True
'23函数' 结果: False
'a2390' 结果: False
#写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串
def isdigit(s):
for i in range(len(s)):
if ( '0' < s[i] < '9'):
continue
else:
return False
break
return True
if __name__ == '__main__':
s = input('请输入要判断的字符串:')
print(isdigit(s))
11、 写一个自己的upper函数,将一个字符串中所有的小写字母变成大写字母
例如: 'abH23好rp1' 结果: 'ABH23好RP1'
def upper(str1):
str2 = ''
for x in range(0, len(str1)):
if 'a' <= str1[x] <= 'z':
b = ord(str1[x]) - 32
str2 += chr(int(b))
else:
str2 += str1[x]
return str2
str1 = input('请输入一个字符串:')
print(upper(str1))
12、写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充
例如: 原字符:'abc' 宽度: 7 字符:'^' 结果: '^^^^abc'
原字符:'你好吗' 宽度: 5 字符:'0' 结果: '00你好吗'
#写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充
def rjust(s,n,t):
a = []
for i in range(n - len(s)):
a.append(t)
for j in range(len(s)):
a.append(s[j])
a = ''.join(a)
return a
if __name__ == '__main__':
n = int(input('请输入指定宽度'))
s = input('请输入字符串')
t = input('请输入填充的字符')
print(rjust(s,n,t))
13、 写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1
例如: 列表: [1, 2, 45, 'abc', 1, '你好', 1, 0] 元素: 1 结果: 0,4,6
列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '赵云' 结果: 0,4
列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '关羽' 结果: -1
#写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1
def index(s,n):
count = 0
for i in range(len(s)):
if (s[i] == n):
count +=1
print(i,end='\t')
if (count <= 0):
print(-1)
if __name__ == '__main__':
s = ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权']
n = input('请输入要查找的字符:')
index(s,n)
14、写一个自己的len函数,统计指定序列中元素的个数
例如: 序列:[1, 3, 5, 6] 结果: 4
序列:(1, 34, 'a', 45, 'bbb') 结果: 5
序列:'hello w' 结果: 7
#写一个自己的len函数,统计指定序列中元素的个数
def len(s):
count = 0
for x in s:
count += 1
return count
if __name__ == '__main__':
s = [1, 3, 5, 6]
print(len(s))
15、写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在
例如: 序列: (12, 90, 'abc') 元素: '90' 结果: False
序列: [12, 90, 'abc'] 元素: 90 结果: True
#写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在
def str_in(s,n):
for i in range(len(s)):
if (s[i] == n):
return True
break
else:
return False
if __name__ == '__main__':
s = (12, 90, 'abc')
n = '90'
print(str_in(s,n))
16、写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串
例如: 原字符串: 'how are you? and you?' 旧字符串: 'you' 新字符串:'me' 结果: 'how are me? and me?'
#写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串
def str_replace(s1,s2,s3):
str1 = ' '
i = 0
while i < len(s1):
if (s1[i] == s2[0]):
if (s1[i:i + len(s2)] == s2):
str1 += s3
i += len(s2)
else:
str1 +=s1[i]
i +=1
else:
str1 +=s1[i]
i +=1
return str1
if __name__ == '__main__':
str1 = 'how are you? Thank you!'
str2 = 'you'
str3 = 'me'
print(str_replace(str1, str2, str3))
17、写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值
#写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值
def max(list1):
if (type(list1) == dict) :
max_num = 0
for x in list1:#取出的是字典的key值
if max_num < list1[x]:
max_num = list1[x]
else:
max_num = list1[0]
for x in list1:
if max_num < x:
max_num = x
return max_num
if __name__ == '__main__':
param1 = [-7, -12, -1, -9]
print(max(param1))
18、写四个函数,分别实现求两个列表的交集、并集、差集、补集的功能
def intersection(s1,s2):
jiao_ji = []
for x in s1:
if x in s2:
jiao_ji.append(x)
return jiao_ji
def union(s1,s2):
bing_ji = []
for x in s1:
bing_ji.append(x)
for y in s2:
if y not in bing_ji:
bing_ji.append(y)
return bing_ji
def difference(s1,s2):
cha_ji = []
for x in s1:
if x not in s2:
cha_ji.append(x)
return cha_ji
def complement(s1,s2):
bu_ji = []
for x in s2:
if x not in s1:
bu_ji.append(x)
return bu_ji
if __name__ == '__main__':
list1 = [2, 4, 6, 8, 10, 12, 14, 16]
list2 = [2, 4, 6, 8]
print(intersection(list1, list2))
print(union(list1, list2))
print(difference(list1, list2))
print(complement(list1, list2))