各位小可爱,下午好~
欢迎大家阅读本期文章,我是栗子同学。
2021年,Python还需要学吗?答案是:当然。
近些年,Python 的火热有目共睹,作为一种功能强大的高级编程语言,在2018 年的时候它的
流行程度就得到了大幅提高。Python以其语法简洁著称。在学习Python的过程中,总是会发现
Python能够轻而易举地帮助我们解决许多问题。有时候看似复杂的任务,甚至是可以使用一行
Python代码就可以搞定。
下面栗子给大家介绍50个有趣且实用的Python简短代码,让我们一起来感受Python的强大~
每个人都是从print函数开始的。
print("hello world")
结果:
int("01110", 2) # 2^3+2^2+2 = 8 + 4 + 2
int("140",8) #96
int("ac1",16)#2753
list(range(9))# [0, 1, 2, 3, 4, 5, 6, 7, 8]
一行代码求解高斯之和:求解1到100的所有数的和
sum(range(1,101)) # range函数不包含101:5050
# 除以2余数为0表示偶数
sum(i for i in range(1,101) if i % 2 == 0) # 2550
# 除以2余数为0表示奇数
sum(i for i in range(1,101) if i % 2 != 0) # 2500
import math # 需要借助第三方的库
math.factorial(6) # 6*5*4*3*2*1 #720
矩阵转置就是实现矩阵的行列转换。
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]
将多个列表合并成一个大列表
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]
栗子1:
a = [1,2,3]
b = [4,5,6]
a.extend(b)
栗子:
a
结果:
[1, 2, 3, 4, 5, 6]
list6 = [1,2,3,4,5,6,7]
list6[::-1]
结果:
[7, 6, 5, 4, 3, 2, 1]
h,*i,j = [1,2,3,4,5]
print(h)
print(i)
print(j)
结果:
1
[2, 3, 4]
5
通过将列表转成集合,利用集合的去重性质后再转成列表
list7 = [1,2,3,4,3,2,3,3]
list(set(list7))
结果:
[1, 2, 3, 4]
filter函数的两个参数:
指定某个函数
待执行的可迭代对象,每个对象执行前面的函数
list(filter(lambda x:x % 3 == 0, [1,3,6,7,9,10])) # 找出3的倍数
结果:
[3, 6, 9]
[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}
栗子1:
s1 = {1,2,3}
s2 = {4,5,6}
s1.update(s2)
栗子2
s1
结果:
{1, 2, 3, 4, 5, 6}
{i:i**3 for i in range(0,5)} # i**3表示i的三次方
结果:
{0: 0, 1: 1, 2: 8, 3: 27, 4: 64}
栗子1:
d1 = {"name1":"xiaoming","age1": 19}
d2 = {"name2":"xiaoming","age2": 28}
d1.update(d2)
栗子2:
d1
结果:
{'name1': 'xiaoming', 'age1': 19, 'name2': 'xiaoming', 'age2': 28}
# 寻找3的倍数
[number for number in range(0,20) if number % 3 == 0]
结果:
[0, 3, 6, 9, 12, 15, 18]
print("偶数") if 8 % 2 == 0 else ("奇数")
偶数
print("偶数") if 9 % 2 == 0 else print("奇数")
奇数
list2 = [9,5,1,6,2,8] # 定义一个列表
sorted(list2) # 默认升序
结果:
[1, 2, 5, 6, 8, 9]
sorted(list2, reverse=True) # 降序
结果:
[9, 8, 6, 5, 2, 1]
list3 = ["ac","ab","bb","aa","bc","cd","ca"]
sorted(list3)
结果:
['aa', 'ab', 'ac', 'bb', 'bc', 'ca', 'cd']
首先我们按照第一个字母的ASCII来排序,默认是升序;a最小。当第一个字母相同,再按照第二个字母排序
"string to bytes".encode()
结果:
b'string to bytes'
import string
string.ascii_letters # 大小写
结果:
'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
string.ascii_uppercase
结果:
'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
string.ascii_lowercase
结果:
'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参数指定函数
结果:
'javascript'
max(list7) # 默认
结果:
'javascript'
"".join(list(filter(lambda x: x.isalpha(), "abcde12hk18")))
结果:
'abcdehk'
list(filter(lambda x: x.isalpha(), "abcde12hk18"))
结果:
['a', 'b', 'c', 'd', 'e', 'h', 'k']
list(map(int, ["10","90","50"]))
结果:
[10, 90, 50]
"python"[::-1]
结果:
'nohtyp'
a, b = 5, 8 # 定义两个变量
print("交换前a:",a)
print("交换前b:",b)
结果:
交换前a: 5
交换前b: 8
a, b = b, a # 一行代码交换
print("交换后a:",a)
print("交换后b:",b)
结果:
交换后a: 8
交换后b: 5
isinstance(5,int) # 数值
结果:
True
isinstance("python",int)
结果:
False
isinstance("python",str) # 字符串
结果:
True
isinstance([1,3,6],list) # 列表
结果:
True
fibo = lambda x: x if x <= 1 else fibo(x-1) + fibo(x-2)
fibo(10)
结果:
55
统计字符串中单个字符的次数
"javascript".count("a")
结果:
2
"javascript".count("s")
结果:
1
"hello".count("l")
结果:
2
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最多
结果:
1
min(list10, key=list10.count) # 元素3最少,只出现一次
结果:
3
import time
time.time() # 时间戳形式
结果:
1632501677.992713
time.ctime() # 标准形式
结果:
'Sat Sep 25 00:09:18 2021'
print("Hi my name is XiaoF".lower())
# 'hi my name is xiaof'
print("Hi my name is XiaoF".casefold())
# 'hi my name is xiaof'
print("hi my name is XiaoF".upper())
# 'HI MY NAME IS XIAOF'
import shutil
shutil.copyfile('source.txt', 'dest.txt')
python3 -m http.server 8000
python2 -m SimpleHTTPServer
while 1:0
import time
print(time.time())
import time
print(time.ctime())
# Thu Aug 13 20:00:00 2021
message = ''.join(list(filter(lambda x: x.isalpha(), 'abc123def4fg56vcg2')))
print(message)
# abcdeffgvcg
result = list(filter(lambda x: x % 2 == 0, [1, 2, 3, 4, 5, 6]))
print(result)
# [2, 4, 6]
a, *b, c = [1, 2, 3, 4, 5]
print(a) # 1
print(b) # [2, 3, 4]
print(c) # 5
好啦!文章写到这里结束啦,快来学习新知识啦~
源码基地:点击即可加入哦!文章的一些免费代码、解答等都可以在这里进行!
1.0 20201——已收录文章汇总 ——持续更新!直接看这篇文章啦~