Python 是一种真正美妙的语言。当有人想出一个好主意时,大约需要 1 分钟和 5 行代码来编写几乎可以满足您要求的东西。然后只需要一个小时就可以将脚本扩展到 300 行,之后它仍然几乎可以满足您的需求。
“Python 是一种真正美妙的语言。当有人想出一个好主意时,大约需要 1 分钟和 5 行代码来编写几乎可以满足您要求的东西。然后只需要一个小时就可以将脚本扩展到 300 行,之后它仍然几乎可以满足您的需求。” - 杰克詹森
你可能使用循环来打印 N 次字符串。但我将向你展示了:在一小行代码中打印 N 次字符串的优美方法。
string = "Python "ntimes = string * 3print(ntimes) # Python Python Python
有时候函数需要返回多个值,我们可以用下面的方式来实现:
def MultiReturn(): return 1,2,3a, b, c = MultiReturn()print(a,b,c) # 1 2 3
你知道我们可以在 Python 中获取任何导入模块的文件路径吗?当你需要知道模块的路径时,这是一个了不起的功能。查看以下代码示例:
import osimport jsonprint(os) # <module 'os' from '/usr/lib/python3.6/os.py'>print(json) # <module 'json' from '/usr/lib/python3.6/json/__init__.py'>
要看懂下面代码,你可能要深入了解 Python 切片操作。
string = "Python"print(string[::-1]) # nohtyP
语法:string[start:end:stop]
许多其他语言 C++、Java、JavaScript 只允许对变量进行一次赋值。但是 Python 允许你执行多个分配,这在不同情况下非常有用。
a, b = 1, 2print(a,b) # 1 2
python 中,你不再需要循环来从列表中删除重复项,你可以使用内置函数以快速简便的方式完成此操作。看看下面的代码。
lst1 = [1, 3, 3, 4, 5, 1]lst2 = ["A", "A", "B", "C", "D", "D"]print(set(lst1)) # {1, 3, 4, 5}print(set(lst2)) # {'A', 'B', 'C', 'D'}
你通常使用 + 一元运算符来格式化字符串。简而言之,当想将变量与字符串附加在一起时,可以使用一元运算符 + 。但我将向你展示如何以简单快捷的方式进行这种格式化。
name = "John"age = 23# method 1print("My name is " + name + " and I am " + str(age)) # My name is John and I am 23# method 2print("My name is {0} and I am {1}".format(name, age)) # My name is John and I am 23# method 3print(f"My name is {name} and I am {age}") # My name is John and I am 23
你可以在 Python 中初始化空容器。简而言之,可以在不分配值或填充它们的情况下声明数据结构。
lst = [] # 初始化一个空列表dct = {} # 初始化一个空字典tpl = () # 初始化一个空元组set = set() # 初始化一个空集合
你知道Python内置模块sys可以告诉你一个对象在python中消耗了多少内存吗?
import sysprint(sys.getsizeof(1)) # 28print(sys.getsizeof(1.0)) # 24print(sys.getsizeof(True)) # 1print(sys.getsizeof(None)) # 1print(sys.getsizeof("Hello")) # 56print(sys.getsizeof([])) # 40print(sys.getsizeof(())) # 40print(sys.getsizeof({})) # 40print(sys.getsizeof(set())) # 40
参照本文第4条,反转字符串。
lst = [1, 3, 3, 4, 5, 1]print(lst[::-1]) # [1, 5, 4, 3, 3, 1]
我将分享一个示例代码来反转字典。简而言之,键和值将交换它们的位置。
dict = {'x' : 1, 'y' : 2, 'z' : 3}new_dict = { value : key for key , value in dict.items()}print(new_dict) # {1: 'x', 2: 'y', 3: 'z'}## 尝试下下面代码,有惊喜dict = {'x' : 1, 'y' : 2, 'z' : 2}new_dict = { value : key for key , value in dict.items()}print(new_dict) # {1: 'x', 2: 'z'}
本文前面,我们已经学会了如何完成多变量复制。在这个技巧中,我们将学习多变量复制的高级方法。
a, *b, c, d = 3, 4, 5, 6, 7print(a) # 3print(b) # [4, 5]print(c) # 6print(d) # 7## ⚠️ 尝试下下面代码a, *b, c= 3, 4, 5, 6, 7print(a) # 3print(b) # [4, 5, 6]print(c) # 7
您可能使用循环来迭代列表并将列表的每个项连接在一起。但是需要很多行代码才能完成。此时可用join()方法以快速简便的方式完成此操作。
lst = ['a', 'b', 'c']print(''.join(lst)) # abc
dict1 = {'a' : 1, 'b' : 2}dict2 = {'c' : 3, 'd' : 4}dict3 = {**dict1, **dict2}print(dict3) # {'a': 1, 'b': 2, 'c': 3, 'd': 4}
当使用递归函数时, Python其实已将默认将递归限制设置为1000,但可以通过如下代码修改其限制:
import syscurrent_recursion_limit = sys.getrecursionlimit()print(current_recursion_limit) # 1000set_limit = sys.setrecursionlimit(2000)print(set_limit) # 2000
你可能已经使用过 startwith 和 endwith 方法来搜索字符串中的前缀或者后缀。但是你不一定知道他们可以使用多个条件。
string1 = 'abc.xls'# method 1if string1.endswith('.xls') or string1.endswith('.xlsx'): print('Yes')# method 2if string1.endswith(('.xls','.xlsx')): print('Yes')
a = [1, 2, 3]x = 1# method 1if a[0] == x or a[1] == x or a[2] == x: print('Number X is present in the list')# method 2if x in a: print('Number X is present in the list')
上面分享的17个提供python的技巧,希望对你有所帮助!
本文链接:http://www.28at.com/showinfo-26-52166-0.html17个提升Python的编码技巧,从此键盘飞起
声明:本网页内容旨在传播知识,不代表本站观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。