13個好用到起飛的Python技巧!
回復(fù)“書籍”即可獲贈Python從入門到進階共10本電子書
列表
1. 將兩個列表合并到一個字典中
zip 這樣的內(nèi)置函數(shù)來克服這個問題。keys_list = ['A', 'B', 'C']
values_list = ['blue', 'red', 'bold']
# 有 3 種方法可以將這兩個列表轉(zhuǎn)換為字典
# 1.使用Python zip、dict函數(shù)
dict_method_1 = dict(zip(keys_list, values_list))
# 2. 使用帶有字典推導(dǎo)式的 zip 函數(shù)
dict_method_2 = {key:value for key, value in zip(keys_list, values_list)}
# 3.循環(huán)使用zip函數(shù)
items_tuples = zip(keys_list, values_list)
dict_method_3 = {}
for key, value in items_tuples:
if key in dict_method_3:
pass
else:
dict_method_3[key] = value
print(dict_method_1)
print(dict_method_2)
print(dict_method_3)

2.將兩個或多個列表合并為一個列表
[1,2,3]、['a','b','c']、['h','e','y'], 和[4,5,6],我們想為這四個列表創(chuàng)建一個新列表;它將是 [[1,'a','h',4], [2,'b','e',5], [3,'c','y',6]] 。def merge(*args, missing_val = None):
max_length = max([len(lst) for lst in args])
outList = []
for i in range(max_length):
outList.append([args[k][i] if i < len(args[k]) else missing_val for k in range(len(args))])
return outList
merge([1,2,3],['a','b','c'],['h','e','y'],[4,5,6])

3. 對字典列表進行排序
dicts_lists = [
{
"Name": "James",
"Age": 20,
},
{
"Name": "May",
"Age": 14,
},
{
"Name": "Katy",
"Age": 23,
}
]
# 方法一
dicts_lists.sort(key=lambda item: item.get("Age"))
# 方法二
from operator import itemgetter
f = itemgetter('Name')
dicts_lists.sort(key=f)

4. 對字符串列表進行排序
my_list = ["blue", "red", "green"]
# 方法一
my_list.sort()
my_list = sorted(my_list, key=len)
# 方法二
import locale
from functools import cmp_to_key
my_list = sorted(my_list, key=cmp_to_key(locale.strcoll))

5. 根據(jù)另一個列表對列表進行排序
a = ['blue', 'green', 'orange', 'purple', 'yellow']
b = [3, 2, 5, 4, 1]
sortedList = [val for (_, val) in sorted(zip(b, a), key=lambda x: x[0])]
print(sortedList)

6. 將列表映射到字典
mylist = ['blue', 'orange', 'green']
#Map the list into a dict using the map, zip and dict functions
mapped_dict = dict(zip(itr, map(fn, itr)))
字典
7. 合并兩個或多個字典
from collections import defaultdict
def merge_dicts(*dicts):
mdict = defaultdict(list)
for dict in dicts:
for key in dict:
res[key].append(d[key])
return dict(mdict)
8. 反轉(zhuǎn)字典
my_dict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
}
# 方法一
my_inverted_dict_1 = dict(map(reversed, my_dict.items()))
# 方法二
from collections import defaultdict
my_inverted_dict_2 = defaultdict(list)
{my_inverted_dict_2[v].append(k) for k, v in my_dict.items()}
print(my_inverted_dict_1)
print(my_inverted_dict_2)

字符串
9. 使用 f 字符串
str_val = 'books'
num_val = 15
print(f'{num_val} {str_val}')
print(f'{num_val % 2 = }')
print(f'{str_val!r}')
price_val = 5.18362
print(f'{price_val:.2f}')
from datetime import datetime;
date_val = datetime.utcnow()
print(f'{date_val=:%Y-%m-%d}')

10. 檢查子串
addresses = ["123 Elm Street", "531 Oak Street", "678 Maple Street"]
street = "Elm Street"
# 方法一
for address in addresses:
if address.find(street) >= 0:
print(address)
# 方法二
for address in addresses:
if street in address:
print(address)

11. 以字節(jié)為單位獲取字符串的大小
str1 = "hello"
str2 = ""
def str_size(s):
return len(s.encode('utf-8'))
print(str_size(str1))
print(str_size(str2))

輸入/輸出操作
12. 檢查文件是否存在
# 方法一
import os
exists = os.path.isfile('/path/to/file')
# 方法二
from pathlib import Path
config = Path('/path/to/file')
if config.is_file():
pass
13.解析電子表格
import csv
csv_mapping_list = []
with open("/path/to/data.csv") as my_data:
csv_reader = csv.reader(my_data, delimiter=",")
line_count = 0
for line in csv_reader:
if line_count == 0:
header = line
else:
row_dict = {key: value for key, value in zip(header, line)}
csv_mapping_list.append(row_dict)
line_count += 1
小伙伴們,快快用實踐一下吧!如果在學(xué)習(xí)過程中,有遇到任何Python問題,歡迎加我好友,我拉你進Python學(xué)習(xí)交流群共同探討學(xué)習(xí)。
------------------- End -------------------
往期精彩文章推薦:

歡迎大家點贊,留言,轉(zhuǎn)發(fā),轉(zhuǎn)載,感謝大家的相伴與支持
想加入Python學(xué)習(xí)群請在后臺回復(fù)【入群】
萬水千山總是情,點個【在看】行不行
評論
圖片
表情
