Professional Documents
Culture Documents
20 Doan Code Can Ghi Nho Khi Lap Trinh Python
20 Doan Code Can Ghi Nho Khi Lap Trinh Python
20 Doan Code Can Ghi Nho Khi Lap Trinh Python
Đoạn mã sau đảo ngược một chuỗi bằng cách sử dụng thao tác cắt (slicing) trong Python.
my_string = "ABCDE"
reversed_string = my_string[::-1]
print(reversed_string)
# Kết quả
# EDCBA
Đoạn code sau có thể được sử dụng để chuyển đổi một chuỗi thành trường chuỗi mới được viết
HOA ký tự đầu tiên của mỗi từ.
Điều này được thực hiện bằng cách sử dụng phương thức title() của String class.
print(new_string)
# kết quả
# Đây Là Một Chuỗi
#3. Tìm các phần tử duy nhất trong một chuỗi
Đoạn code sau có thể được sử dụng để tìm tất cả các phần tử duy nhất trong một chuỗi.
Chúng ta sử dụng tính chất của kiểu dữ liệu set: Tất cả các phần tử trong set là duy nhất.
my_string = "aavvccccddddeee"
print(new_string)
# Kết quả
# acdve
my_string = "abcd"
my_list = [1,2,3]
print(my_string*n)
# abcdabcdabcd
print(my_list*n)
# [1,2,3,1,2,3,1,2,3]
Một trường hợp sử dụng thú vị của điều này có thể là để xác định một list với các giá trị không
đổi - hãy thử xem:
n=4
my_list = [0]*n # n Độ dài của list
# [0, 0, 0, 0]
5. List comprehension
List comprehension cung cấp cho chúng ta một cách đơn giản, thanh lịch để tạo list dựa trên các
list khác.
Đoạn code sau tạo một list mới bằng cách nhân từng phần tử của list cũ với 2.
original_list = [1,2,3,4]
print(new_list)
# [2,4,6,8]
#6. Hoán đổi giá trị giữa hai biến trong Python
Python làm cho việc hoán đổi giá trị giữa 2 biến khá đơn giản mà không cần sử dụng một biến
trung gian khác.
a=1
b=2
a, b = b, a
print(a) # 2
print(b) # 1
333399
Chúng ta có thể tách một chuỗi thành một list chứa các chuỗi con bằng phương thức .split().
Bạn cũng có thể truyền một đối số (dấu phân cách) để hướng dẫn tách chuỗi theo chỉ định của
bạn.
#8. Kết hợp một danh sách các chuỗi thành một chuỗi
Ngược lại ở ví dụ trên, chúng ta có danh sách các chuỗi. Bây giờ ghép chúng lại thành một chuỗi
duy nhất.
Chúng ta sẽ sử dụng phương thức join().
Trong trường hợp này, chúng ta truyền đối số (dấu phân tách) để hướng dẫn ghép chuỗi. (Mình
sẽ sử dụng dấu phảy ,)
# Output
# Tên,tôi,là,NIIT,Hà,Nội
Vì chúng ta đã biết cách đảo ngược chuỗi nên việc kiểm tra một chuỗi có phải chuỗi đối xứng
hay không sẽ rất đơn giản.
my_string = "abcba"
if my_string == my_string[::-1]:
print("Chuỗi đối xứng")
else:
print("Chuỗi không đối xứng")
# Kết quả
# Chuỗi đối xứng
#10. Tình số lần xuất hiện của các phần tử trong một List
Có nhiều cách để làm điều này, nhưng mình thích sử dụng Counter của Python.
Bộ đếm Python theo dõi tần suất của từng phần tử trong container.
Counter() trả về một dictionary với các phần tử là key và số lần xuất hiện là value.
Chúng tôi cũng sử dụng hàm most_common() để lấy phần tử most_frequent (xuất hiện nhiều
nhất) trong List.
# import Counter
from collections import Counter
my_list = ['a','a','b','b','b','c','d','d','d','d','d']
count = Counter(my_list) # Xác định đối tượng counter
Đảo chữ là một từ hoặc cụm từ được hình thành bằng cách sắp xếp lại các chữ cái của một từ
hoặc cụm từ khác nhau.
Nếu các đối tượng Counter của hai chuỗi bằng nhau, thì chúng là đảo chữ cái.
# import Counter
from collections import Counter
if cnt_1 == cnt_2:
print('1 và 2 Đảo chữ')
if cnt_1 == cnt_3:
print('1 và 3 Đảo chữ')
Xử lý lỗi trong Python có thể được thực hiện dễ dàng bằng cách sử dụng khối try / except.
Thêm một câu lệnh else vào khối này rất hữu ích. Nó sẽ chạy khi không có ngoại lệ xảy ra trong
khối try.
Nếu bạn cần chạy một cái gì đó không phân biệt ngoại lệ, hãy sử dụng finaly.
a, b = 1,0
try:
print(a/b)
# Ngoại lệ xảy ra khi b == 0
except ZeroDivisionError:
print("Chia cho số 0")
else:
print("Không có ngoại lệ xảy ra")
finally:
print("Luôn luôn chạy lệnh này!")
Kịch bản sau đây sử dụng phép liệt kê (enumerate) để lặp qua các giá trị trong list cùng với các
chỉ mục (index) của chúng.
# 0: a
# 1: b
# 2: c
# 3: d
# 4: e
#14: Kiểm tra mức sử dụng bộ nhớ của một đối tượng
Đoạn code sau đây có thể được sử dụng để kiểm tra mức sử dụng bộ nhớ của một đối tượng.
import sys
num = 21
print(sys.getsizeof(num))
Nhưng Python 3.5 làm cho quá trình này đơn giản hơn nhiều.
Trong đoạn code được đưa ra dưới đây, hai Dictionaries được hợp nhất.
Lưu ý: Các value của Dictionaries thứ hai sẽ được sử dụng nếu key bị trùng với key trong
Dictionaries thứ nhất.
print(combined_dict)
# Kết quả
# {'apple': 9, 'banana': 4, 'orange': 8}
Nếu bạn muốn giữ các giá trị của chúng, bạn có thể làm như sau:
# Hợp nhất dictionaries và thêm giá trị của key phổ biến trong list
dict3 = mergeDict(dict1, dict2)
print('Dictionary 3 :')
print(dict3)
#16. Tính thời gian thực hiện để thực thi một đoạn code trong Python
Đoạn code sau sử dụng thư viện time để dễ dàng giúp chúng ta tính thời gian thực để thực thi
một đoạn code trong Python.
# In kết quả
print (time_taken_in_micro)
#17. Trải phẳng list trong list
Đôi khi bạn không chắc chắn về mức độ lồng trong list của mình và bạn chỉ muốn trải phẳng tất
cả các phần tử trong đó thành một list duy nhất.
l = [[1,2,3],[3]]
print(flatten(l))
# [1, 2, 3, 3]
print(list(deepflatten(l, depth=3)))
# [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
Bạn có thể tham khảo deepflatten trong module iteration-utilities tại đây.
Nhớ trước khi sử dụng thì cài đặt module iteration-utilities đã nhé.
Đoạn mã sau tạo ra n số mẫu ngẫu nhiên từ một list nhất định bằng thư viện random.
samples = random.sample(my_list,num_samples)
print(samples)
Bạn cũng có thể sử dụng thư viện secrets để tạo các mẫu ngẫu nhiên để mã hóa.
my_list = ['a','b','c','d','e']
num_samples = 2
samples = secure_random.sample(my_list, num_samples)
print(samples)
#19. Chuyển đổi một số thành danh sách các chữ số trong Python
Đoạn code sau sẽ chuyển đổi một số nguyên thành một danh sách các chữ số.
num = 123456
# Sử dụng map
list_of_digits = list(map(int, str(num)))
print(list_of_digits)
# [1, 2, 3, 4, 5, 6]
print(list_of_digits)
# [1, 2, 3, 4, 5, 6]
def unique(l):
if len(l) == len(set(l)):
print("Tất cả phần tử là duy nhất")
else:
print("List có phần tử trùng lặp")
unique([1,2,3,4])
# Tất cả phần tử là duy nhất
unique([1,1,2,3])
# List có phần tử trùng lặp