Python小技巧練習分享
1.反轉數字
問題場景: 把數字 789 轉換為 987。
典型的數字翻轉問題。
解決思路: 將數字的百位十位個位拆解出來,就解開了
編碼如下:
def reverse_number(number): baiwei = int(number/100) shiwei = int(number%100/10) gewei = int(number%10) return gewei*100+shiwei*10+baiwei new_number = reverse_number(789) print(new_number)
2.類的說明文檔
問題場景: 給新創(chuàng)建的類添加說明文檔
解決思路: 在類名下使用三引號即可添加說明文檔,使用 類名,__doc__
可調用該文檔
編碼如下:
class My_Class(object): """你好""" print(My_Class.__doc__)
3.設置 Python 文件的編碼
問題場景: Python 文件設置默認編碼。
解決思路: Python 腳本文件默認是使用 UTF-8 編碼格式進行編碼的,一般無需指定編碼,但我們也可自行設置編碼,Python2 代碼文件一般都帶該行注釋。 設置方式是使用一行注釋,要求格式需滿足下述正則表達式。
編碼如下:
coding[=:]\s*([-\w.]+)
聲明位置在 Python 文件的第一行或者第二行,注意 :
或 =
前沒有空格。
例如下述代碼:
# -*- coding:utf-8 -*-
也可以使用大寫:
# -*- coding:UTF-8 -*-
4.旋轉字符串
問題場景: 一個字符串,一個數字,完成如下操作
- 字符串為
abcde
,數字為 3,則輸出cdeab
; - 字符串為
abcde
,數字為 1,則輸出eabcd
; - 字符串為
abcde
,數字為 0,則輸出abcde
; - ……
解決思路: 一個字符串切片運用的問題。
編碼如下:
def reverse_str(my_str,offset): # 如果數字為 0,順序默認不變 if offset ==0: return my_str left = my_str[:len(my_str)-offset] right = my_str[len(my_str)-offset:] return right + left
5.實現(xiàn)控制臺滾動條
問題場景:在控制臺輸出滾動條。
解決思路:使用字符串格式化進行實現(xiàn),例如用 >
表示進展,用 /
表示未完成的進展,使用 ljust()
方法返回一個原字符串左對齊,并使用填充字符(默認空格)填充至指定長度的新字符串。
編碼如下: 逐步實現(xiàn)
# 打印一行 >>> progress_str = ">" * 100 print(progress_str)
填充一部分 >
,再填充另一部分 /
。
# 打印一行 >>> progress_str = ">"*20 # 填充50個 - progress_str = progress_str.ljust(100,'/') print(progress_str)
實現(xiàn)循環(huán)操作:
import time for i in range(0, 11): time.sleep(0.3) current = i/10 # 進度條 progress_str = '{0:s}{1:.0%}'.format( (int(current*10)*'>').ljust(10, '/'), current) print(progress_str)
為了讓其在一行出現(xiàn),可以修改代碼為如下格式,注意最后一行代碼。
import time for i in range(0, 11): time.sleep(0.3) current = i/10 # 進度條 progress_str = '{0:s}{1:.0%}'.format( (int(current*10)*'>').ljust(10, '/'), current) print(f'\r{progress_str}',end='')
6.print 函數直接寫入文件
問題場景 :如果不希望將 print
函數輸出的內容,打印到控制臺,而是直接輸入到文件中,該如何操作?
解決思路 :print()
函數有一個參數叫做 file
,用它就行。
編碼如下:
file = open('runtime.log', 'a+', encoding='utf-8') print('測試日志', file=file)
7.合并 2 個列表
問題場景 合并 2 個列表,并要求合并之后的列表有順序。 例如 my_list1 = [1,2,3]
, my_list2 = [1,3,5]
,合并之后是 my_list = [1,1,2,3,3,5]
解決思路 先合并 2 個列表,然后判斷其各個元素大小,判斷的時候使用冒泡排序即可完成任務。 編碼如下
def merge(l1, l2): my_list = l1 + l2 n = len(my_list) for i in range(n): for j in range(0, n - i - 1): if my_list[j] > my_list[j + 1]: my_list[j], my_list[j + 1] = my_list[j + 1], my_list[j] print(my_list) if __name__ == '__main__': my_list1 = [4, 2, 6] my_list2 = [1, 3] merge(my_list1, my_list2)
到此這篇關于Python小技巧練習分享的文章就介紹到這了,更多相關Python練習內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python處理字節(jié)串:struct.pack和struct.unpack使用
這篇文章主要介紹了Python處理字節(jié)串:struct.pack和struct.unpack使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01端午節(jié)將至,用Python爬取粽子數據并可視化,看看網友喜歡哪種粽子吧!
端午節(jié)快要到了,旅游?回家?拜訪親友?少不了要帶上粽子.那么:選擇什么牌子的粽子呢?選擇什么口味的粽子呢?選擇什么價格區(qū)間呢?今天爬取了京東上面的 “粽子數據” 進行分析,看看有啥發(fā)現(xiàn)吧!,需要的朋友可以參考下2021-06-06利用python和百度地圖API實現(xiàn)數據地圖標注的方法
這篇文章主要介紹了利用python和百度地圖API實現(xiàn)數據地圖標注的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-05-05詳解利用django中間件django.middleware.csrf.CsrfViewMiddleware防止csrf
這篇文章主要介紹了詳解利用django中間件django.middleware.csrf.CsrfViewMiddleware防止csrf攻擊,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10Python使用py2neo操作圖數據庫neo4j的方法詳解
這篇文章主要介紹了Python使用py2neo操作圖數據庫neo4j的方法,結合實例形式詳細分析了Python使用py2neo操作圖數據庫neo4j的具體步驟、原理、相關使用技巧與操作注意事項,需要的朋友可以參考下2020-01-01