1、氣泡排序
lis = [56,12,1,8,354,10,100,34,56,7,23,456,234,-58] def sortport(): for i in range(len(lis)-1): for j in range(len(lis)-1-i): if lis[j] > lis[j+1]: lis[j],lis[j+1] = lis[j+1],lis[j] return lis
2、計算x的n次方的方法
def power(x, n): s = 1 while n > 0: n = n - 1 s = s * x return s
3、計算a*a + b*b + c*c + ……
def calc(*numbers): sum = 0 for n in numbers: sum = sum + n * n return sum
4、計算階乘n!
def fac(): num = int(input("請輸入一個數字: ")) factorial = 1 # 檢視數字是負數,0 或 正數 if num < 0: print("抱歉,負數沒有階乘") elif num == 0: print("0 的階乘為 1") else: for i in range(1, num + 1): factorial = factorial * i print("%d 的階乘為 %d" % (num, factorial))
def factorial(n): result = n for i in range(1, n): result *= i return result
def fact(n): if n==1: return 1 return n * fact(n - 1)
5、列出當前目錄下的所有檔案和目錄名
[d for d in os.listdir('.')]
6、把一個list中所有的字串變成小寫:
L = ['Hello', 'World', 'IBM', 'Apple'] [s.lower() for s in L]
7、輸出某個路徑下的所有檔案和資料夾的路徑
def print_dir(): filepath = input("請輸入一個路徑:") if filepath == "": print("請輸入正確的路徑") else: for i in os.listdir(filepath): #獲取目錄中的檔案及子目錄列表 print(os.path.join(filepath,i)) #把路徑組合起來 print(print_dir())
8、輸出某個路徑及其子目錄下的所有檔案路徑
def show_dir(filepath): for i in os.listdir(filepath): path = (os.path.join(filepath, i)) print(path) if os.path.isdir(path): #isdir()判斷是否是目錄 show_dir(path) #如果是目錄,使用遞迴方法 filepath = "C:\Program Files\Internet Explorer" show_dir(filepath)
9、輸出某個路徑及其子目錄下所有以.html為字尾的檔案
def print_dir(filepath): for i in os.listdir(filepath): path = os.path.join(filepath, i) if os.path.isdir(path): print_dir(path) if path.endswith(".html"): print(path) filepath = "E:\PycharmProjects" print_dir(filepath)
10、把原字典的鍵值對顛倒並生產新的字典
11、列印九九乘法表
for i in range(1, 10): for j in range(1, i+1): # print('{}x{}={}\t'.format(j, i, i*j), end='') print('%d x %d = %d \t'%(i, j, i*j),end='') print()
通過指定end引數的值,可以取消在末尾輸出回車符,實現不換行。
12、替換列表中所有的3為3a
num = ["harden","lampard",3,34,45,56,76,87,78,45,3,3,3,87686,98,76] # print(num.count(3)) # print(num.index(3)) for i in range(num.count(3)): #獲取3出現的次數 ele_index = num.index(3) #獲取首次3出現的座標 num[ele_index]="3a" #修改3為3 print(num)
13、列印每個名字
L = ["James","Meng","Xin"] for i in range(len(L)): print("Hello,%s"%L[i])
** 善於使用rang(),會使問題變得簡單
14、合併去重
list1 = [2, 3, 8, 4, 9, 5, 6] list2 = [5, 6, 10, 17, 11, 2] list3 = list1 + list2 print(list3) # 不去重只進行兩個列表的組合 print(set(list3)) # 去重,型別為set需要轉換成list print(list(set(list3)))
15、隨機生成驗證碼的兩種方式
import random list1=[] for i in range(65,91): list1.append(chr(i)) #通過for迴圈遍歷asii追加到空列表中 for j in range(97,123): list1.append(chr(j)) for k in range(48,58): list1.append(chr(k)) ma = random.sample(list1,6) print(ma) #獲取到的為列表 ma = ''.join(ma) #將列表轉化為字串 print(ma)
import random,string str1 = "0123456789" str2 = string.ascii_letters # string.ascii_letters 包含所有字母(大寫或小寫)的字串 str3 = str1+str2 ma1 = random.sample(str3,6) #多個字元中選取特定數量的字元 ma1 = ''.join(ma1) #使用join拼接轉換為字串 print(ma1) #通過引入string模組和random模組使用現有的方法
#隨機數字小遊戲 import random i = 1 a = random.randint(0,100) b = int( input('請輸入0-100中的一個數字\n然後檢視是否與電腦一樣:')) while a != b: if a > b: print('你第%d輸入的數字小於電腦隨機數字'%i) b = int(input('請再次輸入數字:')) else: print('你第%d輸入的數字大於電腦隨機數字'%i) b = int(input('請再次輸入數字:')) i+=1 else: print('恭喜你,你第%d次輸入的數字與電腦的隨機數字%d一樣'%(i,b))
16、計算平方根
num = float(input('請輸入一個數字: ')) num_sqrt = num ** 0.5 print(' %0.2f 的平方根為 %0.2f'%(num ,num_sqrt))
17、判斷字串是否只由數字組成
def is_number(s): try: float(s) return True except ValueError: pass try: import unicodedata unicodedata.numeric(s) return True except (TypeError, ValueError): pass return False
print(chri.isdigit()) #檢測字串是否只由數字組成 print(chri.isnumeric()) #檢測字串是否只由數字組成,這種方法是隻針對unicode物件
18、判斷奇偶數
num = int(input("輸入一個數字: ")) if (num % 2) == 0: print("{0} 是偶數".format(num)) else: print("{0} 是奇數".format(num))
while True: try: num = int(input('輸入一個整數:')) #判斷輸入是否為整數 except ValueError: #不是純數字需要重新輸入 print("輸入的不是整數!") continue if num % 2 == 0: print('偶數') else: print('奇數') break
19、判斷閏年
year = int(input("輸入一個年份: ")) if (year % 4) == 0: if (year % 100) == 0: if (year % 400) == 0: print("{0} 是閏年".format(year)) # 整百年能被400整除的是閏年 else: print("{0} 不是閏年".format(year)) else: print("{0} 是閏年".format(year)) # 非整百年能被4整除的為閏年 else: print("{0} 不是閏年".format(year))
year = int(input("請輸入一個年份:")) if (year % 4) == 0 and (year % 100) != 0 or (year % 400) == 0: print("{0}是閏年".format(year)) else: print("{0}不是閏年".format(year))
import calendar year = int(input("請輸入年份:")) check_year=calendar.isleap(year) if check_year == True: print ("%d是閏年"% year) else: print ("%d是平年"% year)
20、獲取最大值
N = int(input('輸入需要對比大小數字的個數:')) print("請輸入需要對比的數字:") num = [] for i in range(1,N+1): temp = int(input('輸入第 %d 個數字:' % i)) num.append (temp) print('您輸入的數字為:',num) print('最大值為:',max(num))
N = int(input('輸入需要對比大小數字的個數:\n')) num = [ int(input('請輸入第 %d 個對比數字: \n'%i))for i in range(1,N+1)] print('您輸入的數字為:',num) print('最大值為: ',max(num))
21、斐波那契數列
斐波那契數列指的是這樣一個數列 0, 1, 1, 2, 3, 5, 8, 13;特別指出:第0項是0,第1項是第一個1。從第三項開始,每一項都等於前兩項之和。
# 判斷輸入的值是否合法 if nterms <= 0: print("請輸入一個正整數。") elif nterms == 1: print("斐波那契數列:") print(n1) else: print("斐波那契數列:") print(n1, ",", n2, end=" , ") while count < nterms: nth = n1 + n2 print(n1+n2, end=" , ") # 更新值 n1 = n2 n2 = nth count += 1
22、十進位制轉二進位制、八進位制、十六進位制
# 獲取輸入十進位制數 dec = int(input("輸入數字:")) print("十進位制數為:", dec) print("轉換為二進位制為:", bin(dec)) print("轉換為八進位制為:", oct(dec)) print("轉換為十六進位制為:", hex(dec))
23、最大公約數
def hcf(x, y): """該函式返回兩個數的最大公約數""" # 獲取最小值 if x > y: smaller = y else: smaller = x for i in range(1, smaller + 1): if ((x % i == 0) and (y % i == 0)): hcf = i return hcf # 使用者輸入兩個數字 num1 = int(input("輸入第一個數字: ")) num2 = int(input("輸入第二個數字: ")) print(num1, "和", num2, "的最大公約數為", hcf(num1, num2))
23、最小公倍數
# 定義函式 def lcm(x, y): # 獲取最大的數 if x > y: greater = x else: greater = y while(True): if((greater % x == 0) and (greater % y == 0)): lcm = greater break greater += 1 return lcm # 獲取使用者輸入 num1 = int(input("輸入第一個數字: ")) num2 = int(input("輸入第二個數字: ")) print( num1,"和", num2,"的最小公倍數為", lcm(num1, num2))
24、簡單計算器
# 定義函式 def add(x, y): """相加""" return x + y def subtract(x, y): """相減""" return x - y def multiply(x, y): """相乘""" return x * y def divide(x, y): """相除""" return x / y # 使用者輸入 print("選擇運算:") print("1、相加") print("2、相減") print("3、相乘") print("4、相除") choice = input("輸入你的選擇(1/2/3/4):") num1 = int(input("輸入第一個數字: ")) num2 = int(input("輸入第二個數字: ")) if choice == '1': print(num1, "+", num2, "=", add(num1, num2)) elif choice == '2': print(num1, "-", num2, "=", subtract(num1, num2)) elif choice == '3': print(num1, "*", num2, "=", multiply(num1, num2)) elif choice == '4': if num2 != 0: print(num1, "/", num2, "=", divide(num1, num2)) else: print("分母不能為0") else: print("非法輸入")
25、生成日曆
# 引入日曆模組 import calendar # 輸入指定年月 yy = int(input("輸入年份: ")) mm = int(input("輸入月份: ")) # 顯示日曆 print(calendar.month(yy, mm))
26、檔案IO
# 寫檔案 with open("test.txt", "wt") as out_file: out_file.write("該文字會寫入到檔案中\n看到我了吧!") # Read a file with open("test.txt", "rt") as in_file: text = in_file.read() print(text)
27、字串判斷
# 測試例項一 print("測試例項一") str = "runoob.com" print(str.isalnum()) # 判斷所有字元都是數字或者字母 print(str.isalpha()) # 判斷所有字元都是字母 print(str.isdigit()) # 判斷所有字元都是數字 print(str.islower()) # 判斷所有字元都是小寫 print(str.isupper()) # 判斷所有字元都是大寫 print(str.istitle()) # 判斷所有單詞都是首字母大寫,像標題 print(str.isspace()) # 判斷所有字元都是空白字元、\t、\n、\r print("------------------------") # 測試例項二 print("測試例項二") str = "Bake corN" print(str.isalnum()) print(str.isalpha()) print(str.isdigit()) print(str.islower()) print(str.isupper()) print(str.istitle()) print(str.isspace())
28、字串大小寫轉換
str = "https://www.cnblogs.com/ailiailan/" print(str.upper()) # 把所有字元中的小寫字母轉換成大寫字母 print(str.lower()) # 把所有字元中的大寫字母轉換成小寫字母 print(str.capitalize()) # 把第一個字母轉化為大寫字母,其餘小寫 print(str.title()) # 把每個單詞的第一個字母轉化為大寫,其餘小寫
29、計算每個月天數
import calendar monthRange = calendar.monthrange(2016,9) print(monthRange)
30、獲取昨天的日期
# 引入 datetime 模組 import datetime def getYesterday(): today=datetime.date.today() oneday=datetime.timedelta(days=1) yesterday=today-oneday return yesterday # 輸出 print(getYesterday())
31、Python list常用操作
1.list負數索引
>>> li ['a', 'b', 'mpilgrim', 'z', 'example'] >>> li[-1] 'example' >>> li[-3] 'mpilgrim' >>> li ['a', 'b', 'mpilgrim', 'z', 'example'] >>> li[1:3] ['b', 'mpilgrim'] >>> li[1:-1] ['b', 'mpilgrim', 'z'] >>> li[0:3] ['a', 'b', 'mpilgrim']
2.list增加元素
>>> li ['a', 'b', 'mpilgrim', 'z', 'example'] >>> li.append("new") >>> li ['a', 'b', 'mpilgrim', 'z', 'example', 'new'] >>> li.insert(2, "new") >>> li ['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new'] >>> li.extend(["two", "elements"]) >>> li ['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new', 'two', 'elements']
3.list搜尋
>>> li ['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new', 'two', 'elements'] >>> li.index("example") 5 >>> li.index("new") 2 >>> li.index("c") Traceback (innermost last): File "<interactive input>", line 1, in ? ValueError: list.index(x): x not in list >>> "c" in li False
4.list刪除元素
>>> li ['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new', 'two', 'elements'] >>> li.remove("z") >>> li ['a', 'b', 'new', 'mpilgrim', 'example', 'new', 'two', 'elements'] >>> li.remove("new") # 刪除首次出現的一個值 >>> li ['a', 'b', 'mpilgrim', 'example', 'new', 'two', 'elements'] # 第二個 'new' 未刪除 >>> li.remove("c") #list 中沒有找到值, Python 會引發一個異常 Traceback (innermost last): File "<interactive input>", line 1, in ? ValueError: list.remove(x): x not in list >>> li.pop() # pop 會做兩件事: 刪除 list 的最後一個元素, 然後返回刪除元素的值。 'elements' >>> li ['a', 'b', 'mpilgrim', 'example', 'new', 'two']
5.list運算子
>>> li = ['a', 'b', 'mpilgrim'] >>> li = li + ['example', 'new'] >>> li ['a', 'b', 'mpilgrim', 'example', 'new'] >>> li += ['two'] >>> li ['a', 'b', 'mpilgrim', 'example', 'new', 'two'] >>> li = [1, 2] * 3 >>> li [1, 2, 1, 2, 1, 2]
6.使用join連結list成為字串
>>> params = {"server":"mpilgrim", "database":"master", "uid":"sa", "pwd":"secret"} >>> ["%s=%s" % (k, v) for k, v in params.items()] ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret'] >>> ";".join(["%s=%s" % (k, v) for k, v in params.items()]) 'server=mpilgrim;uid=sa;database=master;pwd=secret'
7.list分割字串
>>> li = ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret'] >>> s = ";".join(li) >>> s 'server=mpilgrim;uid=sa;database=master;pwd=secret' >>> s.split(";") ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret'] >>> s.split(";", 1) ['server=mpilgrim', 'uid=sa;database=master;pwd=secret']
8.list的對映關係
>>> li = [1, 9, 8, 4] >>> [elem*2 for elem in li] [2, 18, 16, 8] >>> li [1, 9, 8, 4] >>> li = [elem*2 for elem in li] >>> li [2, 18, 16, 8]
9.字典中的解析
>>> params = {"server":"mpilgrim", "database":"master", "uid":"sa", "pwd":"secret"} >>> params.keys() ['server', 'uid', 'database', 'pwd'] >>> params.values() ['mpilgrim', 'sa', 'master', 'secret'] >>> params.items() [('server', 'mpilgrim'), ('uid', 'sa'), ('database', 'master'), ('pwd', 'secret')] >>> [k for k, v in params.items()] ['server', 'uid', 'database', 'pwd'] >>> [v for k, v in params.items()] ['mpilgrim', 'sa', 'master', 'secret'] >>> ["%s=%s" % (k, v) for k, v in params.items()] ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']
10.list過濾
>>> li = ["a", "mpilgrim", "foo", "b", "c", "b", "d", "d"] >>> [elem for elem in li if len(elem) > 1] ['mpilgrim', 'foo'] >>> [elem for elem in li if elem != "b"] ['a', 'mpilgrim', 'foo', 'c', 'd', 'd'] >>> [elem for elem in li if li.count(elem) == 1] ['a', 'mpilgrim', 'foo', 'c']