11个实用又简洁的Python短代码,建议收藏

编程知识 行业动态 更新时间:2024-06-13 00:20:21

目录

前言

         1、单行循环列表

2、获取数据类型

3、获取数字的整数值

4、链式比较

5、字符串乘法器

6、带分隔符打印

7、变量交换

8、字符串变小写

9、统计列表中元素出现频率

10、更新字典

11、非 Pandas 方式读取 csv 文件


前言

普通程序员写的代码和大神写的代码的最大区别就是我们是用代码堆砌功能,很少注重代码品质和效率,而大神们能写出优雅精简的代码,实现一个功能我们需要几十上百行代码,而他们可能一行就解决了!并且他们的代码运行效率还比你高!

今天给大家分享一些常用的Python高效代码片段,希望可以给大家的代码质量带来一点点提高!


1、单行循环列表

mylist = [11,24,56,45,60]
print([i*3 for i in mylist]) #[33, 72, 168, 135, 180]
print([i-10 for i in mylist])
[33, 72, 168, 135, 180] #[1, 14, 46, 35, 50]

这种写法可以减少你的代码行数,而且比较清晰。

2、获取数据类型

mylist = [123, 'python', 34.23, False, [4,5]]
print([type(i) for i in mylist])
# [<class 'int'>, <class 'str'>, <class 'float'>, <class 'bool'>, <class 'list'>]

我们有时候需要知道数据的类型,做对应的转换或者操作。可以这样判断:

print(type(123) == int) # True

3、获取数字的整数值

integer = 8938485
digitz = [int(i) for i in str(integer)]
print(digitz)
# [8, 9, 3, 8, 4, 8, 5]

这里的原理就是先将数字转换为字符串,然后再进行循环获取。

4、链式比较

a =5 
print(1 == a < 2) # False
print(2 < 4 < 5 == a)  # True

看到第一个,是不是会这样理解:1 == a 为 False,False < 2 为 False,所以最后答案为 False。

答案是对的,但是过程是错的。在 Python 中,比较逻辑是这样的:分别比较 1 == a 和 a < 2,两个都为 True,结果才为 True。

按照这个逻辑,自己领会一下第二个的运行逻辑。

5、字符串乘法器

如果需要重复生成字符串,通常我们会这样:

str = ''
for i in range(10):
    str += 'Python'
print(str)
# PythonPythonPythonPythonPythonPythonPythonPythonPythonPython

其实,优雅的方式只需一行:

print('Python'*10)
# PythonPythonPythonPythonPythonPythonPythonPythonPythonPython

6、带分隔符打印

print('123', '234', 100, sep='x')
# 123x234x100

还有另外一种方式:

print('x'.join(['123', '234', '100']))
# # 123x234x100

7、变量交换

d1 = 34
d2 = 23
d1, d2 = d2, d1
print(d1, d2)
# 23 34

8、字符串变小写

mylist = ['ABCD', 'Python', 'I am Chinese']
print([data.lower() for data in mylist])
# ['abcd', 'python', 'i am chinese']

9、统计列表中元素出现频率

import collections
mylist = [10, 11, 12, 3, 3, 11, 11, 33]
print(dict(collections.Counter(mylist)))
# {10: 1, 11: 3, 12: 1, 3: 2, 33: 1}

10、更新字典

mydict = {1: 'Python', 2: 'Javascript', 3: 'Java', 4: 'C#'}
mydict.update({2: 'C'})
print(mydict)
# {1: 'Python', 2: 'C', 3: 'Java', 4: 'C#'}
mydict.update({5: 'Svelte'})
print(mydict)
# {1: 'Python', 2: 'C', 3: 'Java', 4: 'C#', 5: 'Svelte'}

11、非 Pandas 方式读取 csv 文件

import csv 
with open('Test.csv', 'r') as f:
    read = csv.reader(f)
    print([r for r in read])

更多推荐

11个实用又简洁的Python短代码,建议收藏

本文发布于:2023-03-29 19:04:00,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/cfba3b3642a34eb48eaa7dd488287f7d.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:简洁   代码   建议   收藏   Python

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!