分享13个非常有用的Python代码片段

2022-07-05 10:57:40

目录1.将两个列表合并成一个字典2.将两个或多个列表合并为一个包含列表的列表3.对字典列表进行排序4.对字符串列表进行排序5.根据另一个列表对列表进行排序6.将列表映射到字典7.合并两个或多个字典8....

目录
1.将两个列表合并成一个字典
2.将两个或多个列表合并为一个包含列表的列表
3.对字典列表进行排序
4.对字符串列表进行排序
5.根据另一个列表对列表进行排序
6.将列表映射到字典
7.合并两个或多个字典
8.反转字典
9.使用 f 字符串
10.检查子串
11.以字节为单位获取字符串的大小
12.检查文件是否存在
13.解析电子表格

Lists Snippets

我们先从最常用的数据结构列表开始

1.将两个列表合并成一个字典

假设我们在 python 中有两个列表,我们希望将它们合并为字典形式,其中一个列表的项作为字典的键,另一个作为值。这是在用 Python 编写代码时经常遇到的一个非常常见的问题

但是为了解决这个问题,我们需要考虑几个限制,比如两个列表的大小,两个列表中元素的类型,以及其中是否有重复的元素,尤其是我们将使用的元素作为 key 时。我们可以通过使用 zipYfyAzghupv 等内置函数来解决这些问题

keys_list=['A','B','C']
values_list=['blue','red','bold']

#Thereare3waystoconvertthesetwolistsintoadictionary
#1-UsingPython'szip,dictfunctionz
dict_method_1=dict(zip(keys_list,values_list))

#2-Usingthezipfunctionwithdictionarycomprehensions
dict_method_2={key:valueforkey,valueinzip(keys_list,values_list)}

#3-Usingthezipfunctionwithaloop
items_tuples=zip(keys_list,values_list)
dict_method_3={}
forkey,valueinitems_tuples:
ifkeyindict_method_3:
pass#Toavoidrepeatingkeys.
else:
dict_method_3[key]=value

2.将两个或多个列表合并为一个包含列表的列表

另一个常见的任务是当我们有两个或更多列表时,我们希望将它们全部收集到一个大列表中,其中较小列表的所有第一项构成较大列表中的第一个列表

例如,如果我们有 4 个列表 [1,2,3], ['a','b','c'www.cppcns.com;], ['h','e','y'] 和 [4,5, 6],我们想为这四个列表创建一个新列表;它将是 [[1,'a','h',4], [2,'b','e',5], [3,'c','y',6]]

defmerge(*args,missing_val=None):
#missing_valwillbeusedwhenoneofthesmallerlistsisshorterthamtheothers.
#Getthemaximumlengthwithinthesmallerlists.
max_length=max([len(lst)forlstinargs])
outList=[]
foriinrange(max_length):
result.append([args[k][i]ifi<len(args[k])elsemissing_valforkinrange(len(args))])
returnoutList

3.对字典列表进行排序

这一组日常列表任务是排序任务,根据列表中包含的元素的数据类型,我们将采用稍微不同的方式对它们进行排序。

dicts_lists=[
{
"Name":"James",
"Age":20,
},
{
"Name":"May",
"Age":14,
},
{
"Name":"Katy",
"Age":23,
}
]

#Therearedifferentwaystosortthatlist
#1-Usingthesort/sortedfunctionbasedontheage
dicts_lists.sort(key=lambdaitem:item.get("Age"))

#2-Usingitemgettermodulebasedonname
fromoperatorimportitemgetter
f=itemgetter('Name')
dicts_lists.sort(key=f)

4.对字符串列表进行排序

我们经常面临包含字符串的列表,我们需要按字母顺序、长度或我们想要或我们的应用程序需要的任何其他因素对这些列表进行排序

my_list=["blue","red","green"]

#1-Usingsortorsrteddirectlyorwithspecifckeys
my_list.sort()#sortsalphabeticallyorinanascendingorderfornumericdata
my_list=sorted(my_list,key=len)#sortsthelistbasedonthelengthofthestringsfromshortesttolongest.
#Youcanusereverse=Truetofliptheorder

#2-Usinglocaleandfunctools
importlocale
fromfunctoolsimportcmp_to_key
my_list=sorted(my_list,key=cmp_to_key(locale.strcoll))

5.根据另一个列表对列表进行排序

有时,我们可能需要使用一个列表来对另一个列表进行排序,因此,我们将有编程客栈一个数字列表(索引)和一个我们想使用这些索引进行排序的列表

a=['blue','green','orange','purple','yellow']
b=[3,2,5,4,1]
#Uselistcomprehensionstosorttheselists
sortedList=[valfor(_,val)insorted(zip(b,a),key=lambdax:\
x[0])]

6.将列表映射到字典

列表代码片段的最后一个任务,如果给定一个列表并将其映射到字典中,也就是说,我们想将我们的列表转换为带有数字键的字典

mylist=['blue','orange','green']
#Mapthelistintoadictusingthemap,zipanddictfunctions
mapped_dict=dict(zip(itr,map(fn,itr)))

Dictionary Snippets

现在处理的数据类型是字典

7.合并两个或多个字典

假设我们有两个或多个字典,并且我们希望将它们全部合并为一个具有唯一键的字典

fromcollectionsimportdefaultdict
#mergetwoormoredictsusingthecollectionsmodule
defmerge_dicts(*dicts):
mdict=defaultdict(list)
fordictindicts:
forkeyindict:
res[key].append(d[key])
returndict(mdict)

8.反转字典

一个非常常见的字典任务是如果我们有一个字典并且想要翻转它的键和值,键将成为值,而值将成为键

当我们这样做时,我们需要确保没有重复的键。值可以重复,但键不能,并确保所有新键都是可以 hashable 的

my_dict={
"brand":"Ford",
"model":"Mustang",
"year":1964
}
#Invertthedictionarybasedonitscontent
#1-Ifweknowallvaluesareunique.
my_inverted_dict=dict(map(reversed,my_dict.items()))

#2-Ifnon-uniquevaluesexist
fromcollectionsimportdefaultdict
my_inverted_dict=defaultdict(list)
{my_inverted_dict[v].append(k)fork,vinmy_dict.items()}

#3-Ifanyofthevaluesarenothashable
my_dict={value:keyforkeyinmy_inverted_dictforvalueinmy_inverted_dict[key]}

String Snippets

接下来是字符串的处理

9.使用 f 字符串

格式化字符串可能是我们几乎每天都需要完成的一项任务,在 Python 中有多种方法可以格式化字符串,使用 f 字符串是比较好的选择

#Formattingstringswithfstring.
str_val='books'
num_val=15
print(f'{num_val}{str_val}')#15books
print(f'{num_val%2=}')#1
print(f'{str_val!r}')#books

#Dealingwithfloats
price_val=5.18362
print(f'{price_val:.2f}')#5.18

#Formattingdates
fromdatetimeimportdatetime;
date_val=datetime.utcnow()
print(f'{date_val=:%Y-%m-%d}')#date_val=2021-09-24

10.检查子串

一项非常常见的任务就是检查字符串是否在与字符串列表中

addresses=["123ElmStreet","531OakStreet","678MapleStreet"]
street="ElmStreet"

#Thetop2methodstocheckifstreetinanyoftheitemsintheaddresseslist
#1-Usingthefindmethod
foraddressinaddresses:
ifaddress.find(street)>=0:
print(address)

#2-Usingthe"in"keyword
foraddressinaddresses:
ifstreetinaddress:
print(address)

11.以字节为单位获取字符串的大小

有时,尤其是在构建内存关键应用程序时,我们需要知道我们的字符串使用了多少内存

str1="hello"
str2=""

defstr_size(s):
returnlen(s.encode('utf-8'))

str_size(str1)
str_size(str2)

Input/ Output operations

最后我们来看看输入输出方面的代码片段

12.检查文件是否存在

在数据科学和许多其他应用程序中,我们经常需要从文件中读取数据或向其中写入数据,但要做到这一点,我们需要检查文件是否存在,因此,我们需要确保代码

不会因 IO 错误而终止

#Checkingifafileexistsintwoways
#1-UsingtheOSmodule
importos
exists=os.path.isfile('/path/to/file')

#2-Usethepathlibmoduleforabetterperformance
frompathlibimportPath
config=Path('/path/to/file')
ifconfig.is_file():
pass

13.解析电子表格

另一种非常常见的文件交互是从电子表格中解析数据,我们使用 CSV 模块来帮助我们有效地执行该任务

importcsv
csv_mapping_list=[]
withopen("/path/to/data.csv")asmy_data:
csv_reader=csv.reader(my_data,delimiter=",")
line_count=0
forlineincsv_reader:
ifline_count==0:
header=line
else:
row_dict={key:valueforkey,valueinzip(header,line)}
csv_mapping_list.append(row_dict)
line_count+=1

好了,我们一起学习了 13 个代码片段,这些片段简单、简短且高效,无论我们在哪个应用程序领域工作,最终都会在相应的 Python 项目中至少使用其中的一个,所以收藏就是最好的选择!

到此这篇关于分享13个非常有用的Python代码片段的文章就介绍到这了,更多相关Python代码片段内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!