第一次尝试报名蓝桥杯的Python组,好好备战,希望省赛可以拿奖!目前是整理了一些Python的常用函数和常用内置库,后面可能会开始刷题,如果有比较需要记住的知识点,会再写一篇刷题篇

一、输入输出

1.输入字符串和浮点数

n = input()
#字符串可以直接遍历,输入字符串时遇到需要输出字符串的题,可以再建一个字符串用来更新,比如这道题
#输入一个由小写英文字母组成的字符串,请将其中的元音字母(a, e, i, o, u)转换成大写,其它字母仍然保持小写
n= input()
res=''
for i in n:
  if i in 'aeiou':
    res +=i.upper()
  else:
    res+=i
print(res)

n = float(input())#浮点数

2.一行输入多个字母或数字

m,n=map(int,input().split())
#输入一个列表
a=list(map(int,input().split()))

3.转换时间格式

#12:00:00
h,m,s = map(int,t.split(':'))
#h=12 m=00 s=00

4.输入一串数字

s = [int(i) for i in input().split()]

5.输入二维矩阵

for i in range(n):
  mp.append(list(map(int,input().split())))#矩阵中都是数字
  
for i in range(n):
  mp.append(list(input()))#矩阵中都是字符

6.输入例如:

220000

000000

002202时

map=[]
for i in range(N):#N是行数
  map.append(list(input()))

7.向字符串里添加符号

words=['www','ccc','aaa']
print('\n'.join(words))
#使用 join() 方法合并字符串时,它会将列表(或元组)中多个字符串采用固定的分隔符连接在一起。
#join() 方法也是非常重要的字符串方法,它是 split() 方法的逆方法,用来将列表(或元组)中包含的多个字符串连接成一个字符串。

#例如
# 隔空输出
a = [1,2,3,4]
print(' '.join(map(str,a)))   #1 2 3 4

8.保留两位小数

a = 3.1415926
print("%.2f"%a)

9.字符串转化为数字

n = input()
int(i) for i in str(n)

10.字符串格式化的三种方法

v1 = "我是{},今年{}".format("李明",22)

v2 = "我是%s,今年%d岁“ %(”李明“.22)

name = "李明"
age = 22
v3 = f"我是{name},今年{age}岁"

%s 字符串  {:s} 
%d 整数    {:d}
%.2f 浮点数字(用小数点符号,45)   {:.2f}
%.2e 浮点数字(科学计数法)     {:.2e}

11.输出

for i in range(10):
    print(i,end='')#打印在一行
    print(i,end='\n')#换行符结尾

12.切片列表,字符串

a=[起始位置:截止位置:步长]

13.常用内置函数

round(number, digits)    # 对数字number四舍五入保留digits位小数,四舍,五不进,六入
enumerate()    # 迭代器,返回index和value,可用于循环遍历或查找
set(x)    # 将x转化为集合,即去重

set1 & set2    # 求交集
set1 | set2    # 求并集
set2 - set1    # 求差集

二、关于string类型的一些常用函数

S.lower() # 小写
S.upper() # 大写
S.swapcase() #大小写互换 
S.capitalize()  # 只有首字母大写 L love you
S.title# 只要遇到空格都会大写    L Love You
S.ljust(width,[fillchar]) # 输出width个字符,S左对齐,不足部分用fillchar填充,默认的为空格。 
返回字符串第一次出现的索引,如果没有匹配项则返回-1,索引从0开始
S.find#针对字符串,会返回-1
S.index()#针对列表,找不到直接报错
S.find('a', 0,3)#在0-2的索引中找,只返回首次出现的位置
print(s.find('l',1,-1))#指定位置查询
S.rfind('a',0,3)#从右侧开始查找,返回找到的第一个的位置
S.count(substr, start, end) # 计算substr在S中出现的次数 
S.replace(oldstr, newstr, count)#把S中的oldstar替换为newstr,count为替换次数
S.strip(chars)#移除s list中指定的chars字符
S.split(sep, maxsplit) # 以sep为分隔符,把S分成一个list。maxsplit表示分割的次数。
S.join(seq)#.join(): 连接字符串数组。将字符串、元组、列表中的元素以指定的字符(分隔符)连接生成一个新的字符串
例:a='-'
b='helloword'
print(a.join(b))
>h-e-l-l-o-w-o-r-d

三、关于list的一些常用函数

##二维列表:列表中的元素是列表,本质:一维列表
a=[[1,2,3],[3,4,5]]
list.append(lista)#lista当成一个元素加到前面的列表中
lista+listb #才是拼接
list.extend(str)extend()#接受参数为可迭代的值,会把str加入到list中
list.insert(index,obj)
list.remove(obj)#移除第一个匹配项
list.index(obj)#找出某个值第一个匹配项的下标
list.sort()# 由小到大排序
list.reverse() # 将列表进行翻转
list.count(obj) # 返回某个元素在列表里面的个数
list.clear()# 清除列表元素
list(seq)#将字符串转为列表
zip(list1,list2)#用zip封装列表,在for遍历
max(a)#求列表a的最大值
min(a)#求列表a的最小值
sum(a)#求列表a的和

四、关于math库的一些常用函数

1.数学常数
math.e:自然常数 e 的值,约等于 2.71828。

math.pi:圆周率 π 的值,约等于 3.14159。

2.常用数学函数
math.sqrt(x):返回 x 的平方根。

math.pow(x, y):返回 x 的 y 次方。

math.exp(x):返回 e 的 x 次方。

math.log(x, base=math.e):返回 x 的对数。base 参数为对数的底数,默认为自然对数 e。

math.sin(x)、math.cos(x)、math.tan(x):返回 x 的正弦、余弦和正切值。

math.asin(x)、math.acos(x)、math.atan(x):返回 x 的反正弦、反余弦和反正切值。

3.数值运算函数
math.ceil(x):返回不小于 x 的最小整数。

math.floor(x):返回不大于 x 的最大整数。

math.trunc(x):返回 x 的整数部分。

math.modf(x):返回 x 的小数部分和整数部分,以元组形式返回。

math.fabs(x):返回 x 的绝对值。

math.factorial(x):返回 x 的阶乘。

math.gcd(a, b):返回 a 和 b 的最大公约数。

a*b//gcd(a,b)#返回a,b的最小公倍数

4.特殊函数
math.erf(x)、math.erfc(x):返回 x 的误差函数和余误差函数的值。

math.gamma(x)、math.lgamma(x):返回 x 的伽马函数和它的自然对数。

math.comb(n, k)#返回不重复且无顺序地从 n 项中选择 k 项的方式总数

五、关于datetime库的一些函数

1.日期加减

print(datetime.datetime.now() + datetime.timedelta(hours=1))
print(datetime.datetime.now() + datetime.timedelta(days=1))
print(datetime.datetime.now() + datetime.timedelta(weeks=1))

2.修改时间为指定时间

print((datetime.datetime.now() + datetime.timedelta(days=1)).strftime("%Y-%m-%d 00:00:00"))

六、关于re库的一些常用函数

re.match(pattern, string[, flags]):从字符串的开头开始匹配,如果字符串的开头能够匹配正则表达式,就返回匹配对象,否则返回None。其中,pattern是正则表达式,string是需要匹配的字符串,flags是可选的匹配标志。

re.search(pattern, string[, flags]):在字符串中搜索正则表达式的第一个匹配结果,如果找到了匹配结果就返回匹配对象,否则返回None。其中,pattern是正则表达式,string是需要匹配的字符串,flags是可选的匹配标志。

re.findall(pattern, string[, flags]) 搜索字符串中所有满足正则表达式的匹配结果,并以列表形式返回这些匹配结果。其中,pattern是正则表达式,string是需要匹配的字符串,flags是可选的匹配标志。

re.sub(pattern, repl, string[, count, flags]) 用repl替换字符串中所有满足正则表达式的匹配结果,并返回替换后的字符串。其中,pattern是正则表达式,repl是替换字符串,string是需要匹配的字符串,count是可选的替换次数,默认是0

七、关于queue的一些常用函数

1.创建一个FIFO队列对象:

q = queue.Queue()
q.put(1)#向队列中添加元素
q.put(2)
print(q.get())  # 输出1 get()从队列中获取元素
print(q.get())  # 输出2
q.qsize()    # 返回队列长度
q.empty()    # 判断队列是否为空

3.双端队列

q = deque()    # 创建
q.append()    # 入队,从队尾插入
q.appendleft()    # 入队,从队头插入
q.pop()    # 出队,从队尾删除,并返回该值
q.popleft()    # 出队,从队头删除,并返回该值

八、关于itertools的一些常用函数

itertools.permutations()

此函数来生成一个序列的全排列。这个函数接受两个参数,第一个参数是需要排列的序列,第二个参数是排列的长度(可选,默认为序列的长度)。
生成1~3的全排列

for p in permutations:
    print(p)
1
2
输出结果:

(1, 2, 3)
(1, 3, 2)
(2, 1, 3)
(2, 3, 1)
(3, 1, 2)
(3, 2, 1)

如果想生成指定长度的排列,可以在第二个参数中指定排列的长度,如下所示:
生成1~3的2个元素排列

permutations = itertools.permutations([1, 2, 3], 2)
for p in permutations:
    print(p)
输出结果:

(1, 2)
(1, 3)
(2, 1)
(2, 3)
(3, 1)
(3, 2)
itertools.count(start=0, step=1)

这个函数返回一个无限迭代器,从 start 开始,以 step 为步长不断地生成整数。可以使用 itertools.islice() 函数来控制生成的元素个数。

itertools.islice(iterable, start, stop[, step])

iterable:可迭代对象,如列表、元组、字符串等。
start:切片的起始索引。
stop:切片的结束索引,切片生成的元素不包含该索引对应的元素。
step(可选):切片的步长,默认为 1,表示连续的元素。

itertools.cycle(iterable)

这个函数接受一个可迭代对象作为参数,并不断重复生成该对象中的元素。可以使用 itertools.islice() 函数来控制生成的元素个数。

itertools.repeat(object, times=None)

这个函数返回一个无限迭代器,不断重复生成指定的对象。如果指定了 times 参数,则迭代指定的次数。

itertools.chain(*iterables)

这个函数接受一些可迭代对象作为参数,返回一个迭代器,依次将它们中的元素连接在一起。

itertools.compress(data, selectors)

这个函数接受两个可迭代对象作为参数,data 和 selectors。它返回一个迭代器,依次返回 data 中与 selectors 中对应位置为 True 的元素。

itertools.filterfalse(function or None, iterable)

这个函数接受一个函数和一个可迭代对象作为参数,返回一个迭代器,依次返回 iterable 中不满足函数 function 的元素。

itertools.groupby(iterable, key=None)

这个函数接受一个可迭代对象和一个 key 函数作为参数,返回一个迭代器,将 iterable 中的元素按照 key 函数的结果进行分组。

itertools.product(*iterables, repeat=1)

这个函数接受一些可迭代对象作为参数,返回一个迭代器,依次返回它们中的元素的笛卡尔积。

itertools.permutations(iterable, r=None)

这个函数接受一个可迭代对象和一个整数 r 作为参数,返回一个迭代器,依次返回它们中的元素的 r 元排列。

itertools.combinations(iterable, r)

这个函数接受一个可迭代对象和一个整数 r 作为参数,返回一个迭代器,依次返回它们中的元素的 r 元组合。

九、进制转换

bin()用来将任意进制整数转换为二进制数。
oct()用来将任意进制整数转换为八进制数。
hex()用来将任意进制整数转换为十六进制数。
int(x, 2) 将x由二进制转为十进制,其它进制转十进制类似

十、大小写转换

#upper() 方法将字符串中的小写字母转为大写字母。
#lower():所有字母小写
str.upper()
str.lower()

十一、sort和sorted

list.sort(cmp=None, key=None, reverse=False)
#cmp -- 可选参数, 如果指定了该参数会使用该参数的方法进行排序。
#key -- 主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素来进行排序。
#reverse -- 排序规则,reverse = True 降序, reverse = False 升序(默认)。
sort 与 sorted 区别:
sort 是应用在 list 上的方法,sorted 可以对所有可迭代的对象进行排序操作。
list 的 sort 方法返回的是对已经存在的列表进行操作,无返回值,而内建函数 sorted 方法返回的是一个新的 list,而不是在原来的基础上进行的操作。

十二、哈希表和字典

enumerate(sequence, [start=0])#同时列出数据下表和数据
d = {key1 : value1, key2 : value2, key3 : value3 }
print(d[key1])#  values1
del d[key2] # 删除键key2
d.clear()     # 清空字典
del d         # 删除字典
len(dict)#计算字典元素个数,即键的总数。
str(dict)#输出字典,可以打印的字符串表示。
dict.get(key[, value]) 
print ("key1 : ", d.get(key1))#value1
 
d={1:[1,10,199],3:[2,9,16]}
d.items()
含义:返回字典中的键值对列表。
d.items()返回包含键值对的元组列表。每个元组中的第一项是键,第二项是键的值。
list(d.items()) =[(1, [1,10,199]), (3, [2,9,16])] 
for o in d.items():
    ids, ts_ = (i for i in o)    # ids是1,3...号, ts_是[1,10,199],[2,9,16]
    ts_ = sorted(ts_)
print(ids,ts_)#1 [1,10,199]  3 [2,9,16]
 
d.keys()
含义:返回字典中的键列表。
 
d.values()
含义:返回字典中的值列表。

十三、分数

#求1+1/2+1/4+1/8+⋯1/2**19的和
from fractions import Fraction#插入分数模块
sum = 1
for i in range(1,20):
#输入分数时,Fraction开头字母必须大写,否则会报错。
  sum+=Fraction(1,2**i)#表示1/2+......+1/2^19
print(sum)#1048575/524288

十四、求质数

m=[]
for i in range(1,n):
    if i>1:
        for j in range(2,i):
            if i%j==0:
                break
        else:
            m.append(i)
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐