自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

11 個(gè)編程小技巧,使用起來更省心

開發(fā) 前端
正在學(xué) Python 的你并不孤單,有我在這里陪著你每天學(xué)習(xí)一個(gè) Python 小技術(shù),你可以加我微信「somenzz」相互交流。今天我為初學(xué)者整理了 11 個(gè)編程小技巧,使用起來非常省心,相信你看完定會有所收獲。

[[426484]]

正在學(xué) Python 的你并不孤單,有我在這里陪著你每天學(xué)習(xí)一個(gè) Python 小技術(shù)。今天我為初學(xué)者整理了 11 個(gè)編程小技巧,使用起來非常省心,相信你看完定會有所收獲。

1、合并(Merge)兩個(gè)字典

有兩個(gè)字典,dict1、dict2,想把 dict2 的內(nèi)容合并(Merge)到 dict1 中,可以使用 dict1.update(dict2)

  1. In [1]: dict1 = { 'a': 1, 'b': 2} 
  2.  
  3. In [2]: dict2 = { 'b': 3, 'd': 4} 
  4.  
  5. In [3]: dict1.update(dict2) 
  6.  
  7. In [4]: dict1 
  8. Out[4]: {'a': 1, 'b': 3, 'd': 4} 
  9.  
  10. In [5]:  

2、合并(Merge)兩個(gè)字典,但不能改變原始字典

有兩個(gè)字典,dict1、dict2,現(xiàn)在要把 dict1、dict2 的內(nèi)容合并(Merge)到 dict3 中,有兩種方法:

方法一

  1. dict3 = {} 
  2. dict3.update(dict1) 
  3. dict3.update(dict2) 

方法二

  1. dict3 = {**dict1, **dict2} 

方法二使用了 ** 來解包字典,非常簡潔和優(yōu)雅,推薦使用。

3、對包含字典的列表進(jìn)行排序

假如有這樣的列表:

[{"name": "張三", "age": 30 },{"name": "李四", "age": 10 },{"name": "王武", "age": 15 }]

其內(nèi)部元素是一個(gè)字典,如何進(jìn)行自定義排序呢?比如按照 age 進(jìn)行排序:

  1. list1 = [{"name""張三""age": 30 },{"name""李四""age": 10 },{"name""王武""age": 15 }] 
  2. list1.sort(key = lambda x: x["age"]) 
  3. print(list1) 
  4.  
  5. [{'name''李四''age': 10}, 
  6.  {'name''王武''age': 15}, 
  7.  {'name''張三''age': 30}] 

如果不能改變 list1 原有的次序,可以使用內(nèi)建函數(shù) sorted,sorted 返回排序后的結(jié)果,并不改變原始順序:

  1. list1 = [{"name""張三""age": 30 },{"name""李四""age": 10 },{"name""王武""age": 15 }] 
  2. sorted_list = sorted(list1, key = lambda x: x["age"]) 
  3. print(sorted_list) 
  4.  
  5. [{'name''李四''age': 10}, 
  6.  {'name''王武''age': 15}, 
  7.  {'name''張三''age': 30}] 

4、檢查文件是否存在

方法一,使用 os.path 模塊

  1. In [2]: import os 
  2.  
  3. In [3]: if os.path.exists("/usr/bin/passwd"): 
  4.    ...:     print("存在"
  5.    ...: 
  6. 存在 

方法二、使用 pathlib(推薦使用)

  1. In [4]: from pathlib import Path 
  2.  
  3. In [5]: if Path("/usr/bin/passwd").exists(): 
  4.    ...:     print("存在"
  5.    ...: 
  6. 存在 

關(guān)于 pathlib 為什么比 os.path 好用,可以閱讀求求你,別用 os.path 了。

5、獲取某個(gè)目錄最新的文件或目錄

  1. In [7]: import glob 
  2.    ...: import os 
  3.    ...: 
  4.    ...: list_of_files = glob.glob('/Users/aaron/*') # * means all if need specific format 
  5.    ...:  then *.csv 
  6.    ...: latest_file = max(list_of_files, key=os.path.getctime) 
  7.    ...: print(latest_file) 
  8.    ...: 
  9. /Users/aaron/web-service-gin 

更推薦你使用 pathlib

  1. from pathlib import Path 
  2. folder_path = Path('/Users/aaron'
  3. list_of_paths = folder_path.glob('*'
  4. latest_path = max(list_of_paths, key = lambda p: p.stat().st_ctime) 

6、隨機(jī)密碼生成器

將以下內(nèi)容保存為 generate_random_password.py:

  1. import string 
  2. import random 
  3.  
  4. def generate_random_password(): 
  5.     ## 輸入密碼長度 
  6.     length = int(input("請輸入密碼長度:")) 
  7.      
  8.     ## 密碼字符范圍 
  9.     characters = list(string.ascii_letters + string.digits + "!@#$%^&*()"
  10.     random.shuffle(characters) 
  11.      
  12.     ## 隨機(jī)選擇字符 
  13.     password = [] 
  14.     for i in range(length): 
  15.         password.append(random.choice(characters)) 
  16.  
  17.     random.shuffle(password
  18.  
  19.     ## 現(xiàn)實(shí)生成的密碼 
  20.     print("".join(password)) 
  21.  
  22. if __name__ == "__main__"
  23.  
  24.     generate_random_password() 

執(zhí)行結(jié)果

  1. python generate_random_password.py 
  2. 請輸入密碼長度:6 
  3. i3o!(o 

7、將兩個(gè)列表轉(zhuǎn)換為一個(gè)字典

  1. list1 = ['a''b''c'
  2. list2 = [1, 2, 3] 
  3. dictionary = dict(zip(list1, list2)) 
  4. print(dictionary) # {'a': 1, 'b': 2, 'c': 3} 

8、測量小代碼片段的執(zhí)行時(shí)間

  1. import timeit 
  2. start = timeit.default_timer() 
  3. [i for i in range(100000)] 
  4. stop = timeit.default_timer() 
  5. print(stop - start) 

timeit 是標(biāo)準(zhǔn)庫提供的計(jì)時(shí)工具,還可以在命令行這樣使用:

示例 1:命令行界面來比較三個(gè)不同的表達(dá)式。

  1. $ python3 -m timeit '"-".join(str(n) for n in range(100))' 
  2. 10000 loops, best of 5: 30.2 usec per loop 
  3. $ python3 -m timeit '"-".join([str(n) for n in range(100)])' 
  4. 10000 loops, best of 5: 27.5 usec per loop 
  5. $ python3 -m timeit '"-".join(map(str, range(100)))' 
  6. 10000 loops, best of 5: 23.2 usec per loop 

示例 2:通過代碼中比較三個(gè)不同的表達(dá)式。

  1. >>> 
  2. >>> import timeit 
  3. >>> timeit.timeit('"-".join(str(n) for n in range(100))', number=10000) 
  4. 0.3018611848820001 
  5. >>> timeit.timeit('"-".join([str(n) for n in range(100)])', number=10000) 
  6. 0.2727368790656328 
  7. >>> timeit.timeit('"-".join(map(str, range(100)))', number=10000) 
  8. 0.23702679807320237 

timeit 內(nèi)部還可以傳入一個(gè)可調(diào)用對象:

  1. >>> def fun(): 
  2. ...     return "-".join(map(str, range(100))) 
  3. ...  
  4. >>> import timeit 
  5. >>> timeit.timeit(fun, number=10000) 
  6. 0.16171755199999893 
  7. >>>  

9、統(tǒng)計(jì)列表中頻率最高的元素

  1. def most_frequent(list): 
  2.   return max(set(list), key=list.count
  3.  
  4. mylist = [1,1,2,3,4,5,5,1,2,1,] 
  5. print("頻率最高的元素: ", most_frequent(mylist)) 

10、如何避免冗長的 if else 分支

簡單來說,就是借助于字典,把策略寫在字典里面,比如設(shè)計(jì)一個(gè)函數(shù),計(jì)算兩個(gè)數(shù)的加、減、乘、除、n 次方

  1. def calculate(action_des: str, a:int,b:int) -> int
  2.  if action_des == '+'
  3.   return a+b 
  4.  elif action_dex == '-'
  5.   return a-b 
  6.  elif action_dex == '*'
  7.   return a*b 
  8.  elif action_dex == '/'
  9.   return a/b 
  10.  elif action_dex == '**'
  11.   return a**b 

借助于字典,可以不需要使用 if else:

  1. import operator 
  2.  
  3. def calculate(action_des: str, a:int,b:int) -> int
  4.  action = { 
  5.   "+": operator.add
  6.   "-": operator.sub, 
  7.   "/": operator.truediv, 
  8.   "*": operator.mul, 
  9.   "**": pow 
  10.     } 
  11.  return action[action_des](a, b) 

這也是設(shè)計(jì)模式中的策略模式的最小示例。

11、讓列表內(nèi)的元素隨機(jī)排列一下

  1. import random 
  2.  
  3. MyList = [1, 2, 3, 4] 
  4. random.shuffle(MyList) 
  5. print(MyList) # [3, 4, 2, 1] 

最后

以上 11 個(gè)編程小技巧,如果有幫助,點(diǎn)個(gè)贊再滑走吧。

本文轉(zhuǎn)載自微信公眾號「 Python七號」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系 Python七號公眾號。

 

責(zé)任編輯:武曉燕 來源: Python七號
相關(guān)推薦

2021-06-30 09:20:18

NuShell工具Linux

2021-04-18 07:18:31

Chrome

2024-01-30 00:40:10

2020-05-17 16:19:59

JavaScript代碼開發(fā)

2024-06-21 08:21:44

2018-10-23 09:00:00

Linux日志

2023-07-11 15:43:16

JavaScript技巧

2023-10-26 18:03:14

索引Python技巧

2019-07-31 10:24:16

JavaScript瀏覽器口袋妖怪

2020-09-23 09:20:58

代碼Java字符串

2021-11-18 08:20:22

接口索引SQL

2022-06-21 14:30:16

Vim自定義Linux

2015-12-15 12:02:47

華為

2020-08-19 09:22:14

Python語言工具

2020-12-31 10:33:05

Python開發(fā)編程

2012-12-17 09:54:08

2021-01-29 17:40:00

Flyme安卓手機(jī)安全

2021-12-27 14:33:47

Python語言開發(fā)

2024-10-25 15:48:21

GPUPyTorch編程

2022-09-20 07:46:15

重試組件retrying
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號