Trắc nghiệm list trong Python

Kiểu dữ liệu List của Python có một số phương thức giúp chúng ta xử lí các vấn đề liên quan đến nó. Kteam sẽ giúp bạn tìm hiểu các phương thức đó.

Một số phương thức Kteam sẽ không nói rõ về nó vì có một số kiến thức bạn chưa nắm được. Điển hình đó là hàm.

Bên cạnh đó có một số phương thức có dạng biến thể là một hàm sẽ được Kteam đề cập ở một bài trong tương lai

Các phương thức tiện ích

Phương thức count

Cú pháp:

.count[sub, [start, [end]]]

Công dụng: Giống với phương thức count của kiểu dữ liệu chuỗi.

  • Trả về một số nguyên, chính là số lần xuất hiện của sub trong List.
  • Còn start và end là số kĩ thuật slicing [lưu ý không hề có bước].
>>> Kteam = [1, 5, 1, 6, 2, 7]
>>> Kteam.count[1]
2
>>> Kteam.count[3]
0

Phương thức index

Cú pháp:

.index[sub[, start[, end]]]

Công dụng: Tương tự phương thức index của  kiểu dữ liệu chuỗi.

>>> Kteam = [1, 2, 3]
>>> Kteam.index[2]
1
>>> Kteam.index[4]
Traceback [most recent call last]:
  File "", line 1, in 
ValueError: 4 is not in list

Phương thức copy

Cú pháp:

.copy[]

Công dụng: Trả về một List tương tự với List[:]

>>> lst = [1, 2, 3]
>>> another_lst = lst.copy[]  # tương tự lst[:]
>>> another_lst[0] = 4
>>> another_lst
[4, 2, 3]
>>> lst
[1, 2, 3]

Phương thức clear

Cú pháp:

.clear[]

Công dụng: Xóa mọi phần tử có trong List.

Lưu ý: Các phiên bản Python 2.X hoặc dưới Python 3.2 sẽ không có phương thức này

>>> Kteam = [1, 2, 3]
>>> Kteam.clear[]
>>> Kteam
[]

Phương thức trên bản chất không như những cách gán với một List rỗng. Giống như dưới đây:

>>> lst = []
>>> lst = list[]

Phương thức clear sẽ xóa đi các phần tử ở trong List. Các bạn sẽ biết thêm khi biết tới câu lệnh del sẽ được Kteam giới thiệu trong các bài sau.

Để thể hiện rõ sự khác biệt giữa hai trường hợp trên. Kteam sẽ lấy ví dụ để minh họa:

  • Bạn còn nhớ ví dụ về việc Tèo và gấu của tèo dùng chung số tiền chứ?
>>> tien_teo = [50]
>>> tien_teo
[50]
>>> tien_gau_cua_teo = tien_teo  # Tèo và gấu của Tèo đang dùng chung 50 nghìn
>>> tien_gau_cua_teo
[50]
>>> tien_gau_cua_teo = []  # ta gán lại số tiền cô gấu của Tèo là một List rỗng
>>> tien_gau_cua_teo
[]
>>> tien_teo # và đương nhiên, tiền của Tèo không bị ảnh hưởng
[50]

Tiếp đến, ta sẽ dùng phương thức clear.

>>> tien_teo = [50]
>>> tien_teo
[50]
>>> tien_gau_cua_teo = tien_teo # Tèo và gấu của Tèo đang dùng chung 50 nghìn
>>> tien_gau_cua_teo
[50]
>>> tien_gau_cua_teo.clear[] # xử dụng phương thức clear
>>> tien_gau_cua_teo
[]
>>> tien_teo # tiền của Tèo đã bị xóa theo
[]

Các phương thức cập nhật

Phương thức append

Cú pháp:

.append[x]

Công dụng: Thêm phần tử x vào cuối List

>>> howkteam = [1, 2]
>>> howkteam.append[3]
>>> howkteam
[1, 2, 3]
>>> howkteam.append[[4, 5]] # chú ý trường hợp này
>>> howkteam
[1, 2, 3, [4, 5]]

Chú ý: Đừng bao giờ append một list vào chính nó.

>>> a = [1, 2]
>>> a.append[a]
>>> a
[1, 2, [...]]

Khi ta append một list vào chính nó, thì trên thực tế, nó sẽ tạo ra một vòng lặp vô tận. Trong ví dụ trên, khi ta append a vào list a, thì nó sẽ truy xuất giá trị của a để có thể append. Nhưng vì giá trị của a đang được thay đổi, nên nó sẽ lại append trước khi truy xuất. Điều này sẽ lặp lại mãi mãi vì giá trị a sẽ luôn luôn được thay đổi. Kết quả [1, 2, [...]] chính là đại diện cho sự lặp vô tận đó.

Phương thức extend

Cú pháp:

.extend[iterable]

Công dụng: Thêm từng phần tử một của iterable vào cuối List.

>>> Kteam = [1, 2, 3]
>>> Kteam.extend[[4, 5]] # xem sự khác biệt giữa append và extend
>>> Kteam
[1, 2, 3, 4, 5]
>>> Kteam.extend[[[6, 7], 8]]
>>> Kteam
[1, 2, 3, 4, 5, [6, 7], 8]

Phương thức insert

Cú pháp:

.insert [i, x]

Công dụng: Thêm phần x vào vị trí i ở trong List.

>>> Kteam = [1, 2, 3]
>>> Kteam.index[2]
1
>>> Kteam.index[4]
Traceback [most recent call last]:
  File "", line 1, in 
ValueError: 4 is not in list
0

Nếu vị trí i lại lớn hơn hoặc bằng số phần tử ở trong List thì kết quả sẽ tương tự như phương thức append.

>>> Kteam = [1, 2, 3]
>>> Kteam.index[2]
1
>>> Kteam.index[4]
Traceback [most recent call last]:
  File "", line 1, in 
ValueError: 4 is not in list
1

Nếu vị trí i là một số âm, bạn cần lưu ý kỹ ví dụ sau. Bạn chắc vẫn còn nhớ về việc indexing với vị trí là một số âm? nếu không nhớ bạn có thể xem lại bài KIỂU DỮ LIỆU CHUỖI TRONG PYTHON – Phần 2 trước khi vào ví dụ này.

>>> Kteam = [1, 2, 3]
>>> Kteam.index[2]
1
>>> Kteam.index[4]
Traceback [most recent call last]:
  File "", line 1, in 
ValueError: 4 is not in list
2

Khi bạn insert mà lại dùng vị trí i là số âm, thì vị trí được insert sẽ là i –1.

>>> Kteam = [1, 2, 3]
>>> Kteam.index[2]
1
>>> Kteam.index[4]
Traceback [most recent call last]:
  File "", line 1, in 
ValueError: 4 is not in list
3

Nếu vị trí i –1 [đang xét indexing âm] không có trong List, mặc định, phần tử x sẽ được thêm vào đầu List

>>> Kteam = [1, 2, 3]
>>> Kteam.index[2]
1
>>> Kteam.index[4]
Traceback [most recent call last]:
  File "", line 1, in 
ValueError: 4 is not in list
4

Chú ý: Cũng giống như phương thức append, Kteam khuyên bạn đừng bao giờ insert một list vào chính nó, bất kể ở vị trí nào.

Cú pháp:

.pop[[i]]

Công dụng: Bỏ đi phần tử thứ i trong List và trả về giá trị đó. Nếu vị trí i không được cung cấp, phương thức này sẽ tự bỏ đi phần tử cuối cùng của List và trả về giá trị đó.

>>> Kteam = [1, 2, 3]
>>> Kteam.index[2]
1
>>> Kteam.index[4]
Traceback [most recent call last]:
  File "", line 1, in 
ValueError: 4 is not in list
5

Phương thức remove

Cú pháp:

.remove[x]

Công dụng: Bỏ đi phần tử đầu tiên trong List có giá trị x. Nếu trong List không có giá trị x sẽ có lỗi được thông báo

>>> Kteam = [1, 2, 3]
>>> Kteam.index[2]
1
>>> Kteam.index[4]
Traceback [most recent call last]:
  File "", line 1, in 
ValueError: 4 is not in list
6

Các phương thức xử lí

Phương thức reverse

Cú pháp:

.reverse[]

Công dụng: Đảo ngược các phần tử ở trong List.

>>> Kteam = [1, 2, 3]
>>> Kteam.index[2]
1
>>> Kteam.index[4]
Traceback [most recent call last]:
  File "", line 1, in 
ValueError: 4 is not in list
7

Phương thức sort

Phương thức sort giúp ta sắp xếp một list theo một thứ tự nào đó [có thể sắp xếp một cách mặc định, hoặc sắp xếp theo cách mà chúng ta muốn]

Cú pháp:

.sort[key=None, reverse=False]

Công dụng:  Sắp xếp các phần tử từ bé đến lớn bằng cách so sánh trực tiếp.

Trong đó:

  • Nếu reverse là False [false là giá trị mặc định], list sẽ được sắp xếp từ bé đến lớn [các phần tử nhỏ hơn sẽ đứng trước], và ngược lại, nếu reverse là True, list sẽ được sắp xếp từ lớn đến bé.
  • Tham số key mặc định là None [tức là sẽ sắp xếp một cách mặc định]. Còn nếu key được chỉ định, thì các phần tử được sắp xếp theo cái “quy ước” của key.

Ví dụ 1: sắp xếp các list [key = None]

>>> Kteam = [1, 2, 3]
>>> Kteam.index[2]
1
>>> Kteam.index[4]
Traceback [most recent call last]:
  File "", line 1, in 
ValueError: 4 is not in list
8

Vì sao nói nó là so sánh trực tiếp. Bởi vì không chỉ số, nó còn so sánh cả chuỗi, cả List, và mọi thứ khác.

>>> Kteam = [1, 2, 3]
>>> Kteam.index[2]
1
>>> Kteam.index[4]
Traceback [most recent call last]:
  File "", line 1, in 
ValueError: 4 is not in list
9

Ghi nhớ rằng, các phần tử phải có thể so sánh với nhau. Trường hợp dưới đây bạn không thể so sánh chuỗi với số được, do đó sẽ có lỗi hiện lên.

>>> lst = [1, 2, 3]
>>> another_lst = lst.copy[]  # tương tự lst[:]
>>> another_lst[0] = 4
>>> another_lst
[4, 2, 3]
>>> lst
[1, 2, 3]
0

Chúng ta sẽ nói đến từ khóa reverse. Từ khóa này bạn chỉ có thể cho 2 giá trị, một là True, hai là False.

  • Nếu là False, các phần tử được sắp xếp từ bé đến lớn, còn ngược lại là từ lớn đến bé.
>>> lst = [1, 2, 3]
>>> another_lst = lst.copy[]  # tương tự lst[:]
>>> another_lst[0] = 4
>>> another_lst
[4, 2, 3]
>>> lst
[1, 2, 3]
1

Ví dụ 2: sắp xếp các list [có tham số key được truyền vào]

>>> lst = [1, 2, 3]
>>> another_lst = lst.copy[]  # tương tự lst[:]
>>> another_lst[0] = 4
>>> another_lst
[4, 2, 3]
>>> lst
[1, 2, 3]
2

Chúng ta có thể thấy rõ ràng rằng: Cùng một giá trị ban đầu, cùng một phương thức sort, nhưng giá trị sau khi sort lại khác nhau hoàn toàn. Nguyên nhân ở đây chính là nằm ở tham số key. Trong ví dụ trên, đối với list a, chương trình sẽ sắp xếp theo mặc định [so sánh trực tiếp 2 chuỗi, đưa chuỗi nhỏ hơn về đầu list]. Còn đối với list b, chương trình sẽ sắp xếp dựa trên việc so sánh độ dài của các chuỗi [vì key = len, tức là lấy độ dài]. Kết quả của b sau khi sort là một list có các chuỗi với độ dài tăng dần.

Bằng cách truyền cho tham số key một phương thức nào đó [hoặc là một hàm – Khái niệm mà Kteam sẽ đề cập trong tương lai], ta có thể để cho một list được sắp xếp theo cách của mình. Ví dụ dưới đây là một cách sắp xếp một list với cả chuỗi và số, dựa trên việc chuyển toàn bộ các số sang kiểu chuỗi và so sánh.

>>> lst = [1, 2, 3]
>>> another_lst = lst.copy[]  # tương tự lst[:]
>>> another_lst[0] = 4
>>> another_lst
[4, 2, 3]
>>> lst
[1, 2, 3]
3

Vì đây là một phần tương đối mới, nên khi các bạn tiếp cận với khái niệm hàm, Kteam sẽ thêm các ví dụ kèm giải thích để các bạn hiểu rõ hơn.

Củng cố bài học

Đáp án bài trước

Bạn có thể tìm thấy câu hỏi của phần này tại CÂU HỎI CỦNG CỐ trong bài KIỂU DỮ LIỆU LIST TRONG PYTHON – Phần 1.

  1. Những đáp án c, d là các cách khởi tạo đúng
  2. Không, vì ta có thể thay đổi nội dung của List
  3. Đáp án 
>>> lst = [1, 2, 3]
>>> another_lst = lst.copy[]  # tương tự lst[:]
>>> another_lst[0] = 4
>>> another_lst
[4, 2, 3]
>>> lst
[1, 2, 3]
4

Câu hỏi củng cố

  1. Chuyện gì xảy ra khi ta dùng phương thức pop lên một List rỗng
>>> lst = [1, 2, 3]
>>> another_lst = lst.copy[]  # tương tự lst[:]
>>> another_lst[0] = 4
>>> another_lst
[4, 2, 3]
>>> lst
[1, 2, 3]
5
  1. Ta có thể sắp xếp được List dưới đây bằng phương thức sort hay không?
>>> lst = [1, 2, 3]
>>> another_lst = lst.copy[]  # tương tự lst[:]
>>> another_lst[0] = 4
>>> another_lst
[4, 2, 3]
>>> lst
[1, 2, 3]
6

Đáp án của phần này sẽ được trình bày ở bài tiếp theo. Tuy nhiên, Kteam khuyến khích bạn tự trả lời các câu hỏi để củng cố kiến thức cũng như thực hành một cách tốt nhất! 

Kết luận

Qua bài viết này, Bạn đã hiểu thêm về các phương thức của KIỂU DỮ LIỆU LIST TRONG PYTHON 

Ở bài sau. Kteam sẽ giới thiệu tới bạn một container nữa đó chính là KIỂU DỮ LIỆU TUPLE TRONG PYTHON.

Cảm ơn bạn đã theo dõi bài viết. Hãy để lại bình luận hoặc góp ý của mình để phát triển bài viết tốt hơn. Đừng quên “Luyện tập – Thử thách – Không ngại khó”.

Thảo luận

Nếu bạn có bất kỳ khó khăn hay thắc mắc gì về khóa học, đừng ngần ngại đặt câu hỏi trong phần BÌNH LUẬN bên dưới hoặc trong mục HỎI & ĐÁP trên thư viện Howkteam.com để nhận được sự hỗ trợ từ cộng đồng.

Chủ Đề