炫技!一行Python代码
转载
公众号:尤而小屋
作者:Peter
编辑:Peter
大家好,我是Peter~
Python以其语法简洁著称。本文主要是通过一行Python代码来实现各种小需求,一起来感受Python的强大~
hello python
二进制转十进制
int("01110", 2) # 2^3+2^2+2
八进制转十进制
十六进制转十进制
生成连续数值列表
[0, 1, 2, 3, 4, 5, 6, 7, 8]
高斯求和
一行代码求解高斯之和
sum(range(0,101)) # range函数不包含101
求解奇、偶数之和
# 除以2余数为0表示偶数
sum(i for i in range(0,101) if i % 2 == 0)
# 除以2余数为0表示奇数
sum(i for i in range(0,101) if i % 2 != 0)
嵌套列表合并
将多个列表合并成一个大列表
list4 = [[1,2,3],[4,5,6],[7,8,9]] # 定义一个列表
list(item for list5 in list4 for item in list5) # 从大到小
[1, 2, 3, 4, 5, 6, 7, 8, 9]
列表合并
a = [1,2,3]
b = [4,5,6]
a.extend(b)
列表反转
list6 = [1,2,3,4,5,6,7]
list6[::-1]
列表解包
h,*i,j = [1,2,3,4,5]
print(h)
print(i)
print(j)
列表去重
通过将列表转成集合,利用集合的去重性质后再转成列表
list7 = [1,2,3,4,3,2,3,3]
list(set(list7))
列表过滤
filter函数的两个参数:
- 指定某个函数
- 待执行的可迭代对象,每个对象执行前面的函数
list(filter(lambda x:x % 3 == 0, [1,3,6,7,9,10])) # 找出3的倍数
列表推导式
[number for number in range(0,11)] # []
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
集合推导式
{number for number in range(0,11)} # {}
{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
合并集合
s1 = {1,2,3}
s2 = {4,5,6}
s1.update(s2)
字典推导式
{i:i**3 for i in range(0,5)} # i**3表示i的三次方
{0: 0, 1: 1, 2: 8, 3: 27, 4: 64}
合并字典
d1 = {"name1":"xiaoming","age1": 19}
d2 = {"name2":"xiaoming","age2": 28}
d1.update(d2)
{'name1': 'xiaoming', 'age1': 19, 'name2': 'xiaoming', 'age2': 28}
阶乘
import math # 需要借助第三方的库
math.factorial(6) # 6*5*4*3*2*1
矩阵转置
矩阵转置就是实现矩阵的行列转换
list1 = [[1,4,7], [2,5,8], [3,6,9]] # 定义一个嵌套列表
list(list(x) for x in zip(*list1)) # list函数实现
[[1, 2, 3], [4, 5, 6], [7, 8, 9]]
[list(x) for x in zip(*list1)] # [] 符号实现
[[1, 2, 3], [4, 5, 6], [7, 8, 9]]
for x in zip(*list1):
print(list(x))
[1, 2, 3]
[4, 5, 6]
[7, 8, 9]
if-for
# 寻找3的倍数
[number for number in range(0,20) if number % 3 == 0]
if-else
print("偶数") if 8 % 2 == 0 else ("奇数")
print("偶数") if 9 % 2 == 0 else print("奇数")
快速排序
list2 = [9,5,1,6,2,8] # 定义一个列表
sorted(list2) # 默认升序
sorted(list2, reverse=True) # 降序
list3 = ["ac","ab","bb","aa","bc","cd","ca"]
sorted(list3)
['aa', 'ab', 'ac', 'bb', 'bc', 'ca', 'cd']
首先我们按照第一个字母的ASCII来排序,默认是升序;a最小。当第一个字母相同,再按照第二个字母排序
字符串转成字节
"string to bytes".encode()
获取26个字母表
import string
string.ascii_letters # 大小写
'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
获取大写字母表
'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
获取小写字母表
'abcdefghijklmnopqrstuvwxyz'
字符串大小写转化
"Hello! My name is Peter".lower() # 转成小写
'hello! my name is peter'
# 转成小写的另一种写法
"Hello! My name is Peter".casefold()
'hello! my name is peter'
"Hello! My name is Peter".upper() # 转成全部大写
'HELLO! MY NAME IS PETER'
"Hello! My name is Peter".title() # 转成首字母大写
'Hello! My Name Is Peter'
寻找最长字符串
list7 = ["c","html","javascript","java"]
max(list7, key=len) # key参数指定函数
删除字符串中的数字
"".join(list(filter(lambda x: x.isalpha(), "abcde12hk18")))
list(filter(lambda x: x.isalpha(), "abcde12hk18"))
['a', 'b', 'c', 'd', 'e', 'h', 'k']
列表中的字符串变成数值
list(map(int, ["10","90","50"]))
字符串反转
交换变量
print("交换前a:",a)
print("交换前b:",b)
print("交换后a:",a)
print("交换后b:",b)
数据类型检查
isinstance("python",str) # 字符串
isinstance([1,3,6],list) # 列表
斐波那契数列
fibo = lambda x: x if x <= 1 else fibo(x-1) + fibo(x-2)
fibo(10)
统计词频
统计字符串中单个字符出现的次数情况
统计列表元素个数
import pandas as pd
list10 = [1,3,4,6,1,2,3,1,1,2,5,6,2]
pd.value_counts(list10)
1 4
2 3
3 2
6 2
4 1
5 1
dtype: int64
统计字符串元素个数
from collections import Counter
Counter("abcdeabcdabcaba")
Counter({'a': 5, 'b': 4, 'c': 3, 'd': 2, 'e': 1})
统计最多元素
list10 = [1,3,4,6,1,2,3,1,1,2,4,6,2]
max(list10, key=list10.count) # 元素1最多
min(list10, key=list10.count) # 元素3最少,只出现一次
当前时间
import time
time.time() # 时间戳形式
'Sat Sep 25 00:41:18 2021'