Làm thế nào để bạn lấy một mảng ký tự trong python?

Python không có kiểu dữ liệu Array sẵn có; . Do đó, bạn có thể coi danh sách Python là một mảng trong ví dụ này

Chuỗi Python thành mảng

Để chuyển Chuỗi thành mảng trong Python, hãy sử dụng Chuỗi. phương pháp tách []. chuỗi. split[] tách Chuỗi khỏi dấu phân cách và trả về các phần tử của bộ chia dưới dạng các mục danh sách riêng lẻ. Phương thức tách chuỗi Python [] chia chuỗi thành một danh sách. Bạn có thể chỉ định dấu phân cách;

cú pháp

string.split[separator, maxsplit]

Thông số

Cả hai tham số là tùy chọn

Nó nhận dấu phân cách làm tham số tùy chọn được sử dụng để phân tách Chuỗi. Theo mặc định, khoảng trắng là dấu phân cách

Tham số maxsplit chỉ định số lượng phân tách cần thực hiện. Giá trị mặc định là -1, là “tất cả các lần xuất hiện“

Thí dụ

# app.py

str = "Millie Bobby Brown is Enola Holmes"
arr = str.split[]
print[arr]

đầu ra

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']

Trong ví dụ này, chúng tôi chưa cung cấp rõ ràng dấu phân cách, do đó, nó sẽ lấy khoảng trắng làm dấu phân cách và phân tách Chuỗi dựa trên dấu phân cách đó và trả về danh sách

Để tách Chuỗi thành một ký tự cụ thể, hãy sử dụng hàm split[] của Python

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]

đầu ra

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']

Trong ví dụ này, chúng tôi tách Chuỗi tại dấu phân cách ','

Chuỗi Python thành mảng ký tự

Chuỗi Python là một chuỗi các ký tự. Chúng ta có thể chuyển đổi nó thành mảng ký tự bằng cách sử dụng hàm sẵn có list[]. Khi chuyển đổi một chuỗi thành một mảng ký tự, khoảng trắng cũng được coi là ký tự

# app.py

str = "MillieB11"
arr = list[str]
print[arr]

đầu ra

['M', 'i', 'l', 'l', 'i', 'e', 'B', '1', '1']

Trong ví dụ này, tách Chuỗi bằng cách chuyển đổi Chuỗi thành danh sách [dùng typecast]

Facebook

Twitter

Pinterest

WhatsApp

Bài viết trước Cách xoay hình ảnh trong Python bằng OpenCV

Bài viết tiếp theo Cách thêm và đọc dữ liệu trong SQLite bằng Python

kranal

https. //appdividend. com/

Krunal Lathiya là một kỹ sư công nghệ thông tin. Theo chuyên môn, anh ấy là một nhà phát triển web có kiến ​​thức về nhiều nền tảng back-end [e. g. , PHP, Nút. js, Python] và các khung JavaScript giao diện người dùng [e. g. , Góc, Phản ứng và Vue]

Trong hướng dẫn về Các kiểu dữ liệu cơ bản trong Python, bạn đã học cách xác định chuỗi. các đối tượng chứa chuỗi dữ liệu ký tự. Xử lý dữ liệu ký tự là không thể thiếu trong lập trình. Đây là một ứng dụng hiếm hoi không cần thao tác với chuỗi ít nhất ở một mức độ nào đó

Đây là những gì bạn sẽ học trong hướng dẫn này. Python cung cấp một tập hợp phong phú các toán tử, hàm và phương thức để làm việc với chuỗi. Khi bạn hoàn thành hướng dẫn này, bạn sẽ biết cách truy cập và trích xuất các phần của chuỗi, đồng thời làm quen với các phương thức có sẵn để thao tác và sửa đổi dữ liệu chuỗi

Bạn cũng sẽ được giới thiệu về hai đối tượng Python khác được sử dụng để biểu diễn dữ liệu byte thô, các loại

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 và
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
30

Lấy bài kiểm tra. Kiểm tra kiến ​​thức của bạn với bài kiểm tra tương tác “Chuỗi trăn và dữ liệu ký tự” của chúng tôi. Sau khi hoàn thành, bạn sẽ nhận được điểm số để có thể theo dõi quá trình học tập của mình theo thời gian

Lấy bài kiểm tra "

Thao tác chuỗi

Các phần bên dưới nêu bật các toán tử, phương thức và hàm có sẵn để làm việc với chuỗi

Loại bỏ các quảng cáo

Toán tử chuỗi

Bạn đã thấy các toán tử

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
31 và
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
32 được áp dụng cho các toán hạng số trong hướng dẫn về Toán tử và Biểu thức trong Python. Hai toán tử này cũng có thể được áp dụng cho chuỗi

Toán tử
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
31

Toán tử

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
31 nối các chuỗi. Nó trả về một chuỗi bao gồm các toán hạng được nối với nhau, như được hiển thị ở đây

>>>

# app.py

str = "Millie Bobby Brown is Enola Holmes"
arr = str.split[]
print[arr]
3

Toán tử
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
32

Toán tử

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
32 tạo nhiều bản sao của một chuỗi. Nếu
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 là một chuỗi và
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
38 là một số nguyên, một trong hai biểu thức sau sẽ trả về một chuỗi bao gồm các bản sao
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
38 nối của
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
41
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
42

Dưới đây là ví dụ về cả hai hình thức

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'

Toán hạng số nhân

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
38 phải là một số nguyên. Bạn nghĩ rằng nó bắt buộc phải là một số nguyên dương, nhưng thật thú vị, nó có thể bằng 0 hoặc âm, trong trường hợp đó, kết quả là một chuỗi rỗng

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
4

Nếu bạn tạo một biến chuỗi và khởi tạo nó thành chuỗi rỗng bằng cách gán cho nó giá trị

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
44, thì bất kỳ ai cũng sẽ nghĩ bạn hơi ngớ ngẩn. Nhưng nó sẽ hoạt động

Nhà điều hành
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
45

Python cũng cung cấp một toán tử thành viên có thể được sử dụng với các chuỗi. Toán tử

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
45 trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 nếu toán hạng đầu tiên được chứa trong toán hạng thứ hai và
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
48 nếu ngược lại

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
0

Ngoài ra còn có một toán tử

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
49, ngược lại

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
2

Hàm chuỗi tích hợp

Như bạn đã thấy trong hướng dẫn về Các kiểu dữ liệu cơ bản trong Python, Python cung cấp nhiều hàm được tích hợp sẵn cho trình thông dịch và luôn có sẵn. Dưới đây là một số hoạt động với chuỗi

Chức năng Mô tả

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
50Chuyển đổi một số nguyên thành một ký tự
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
51Chuyển đổi một ký tự thành một số nguyên
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
52Trả về độ dài của một chuỗi
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
53Trả về một chuỗi đại diện của một đối tượng

Chúng được khám phá đầy đủ hơn dưới đây

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
54

Trả về một giá trị số nguyên cho ký tự đã cho

Ở cấp độ cơ bản nhất, máy tính lưu trữ tất cả thông tin dưới dạng số. Để biểu diễn dữ liệu ký tự, lược đồ dịch được sử dụng để ánh xạ từng ký tự thành số đại diện của nó

Sơ đồ đơn giản nhất được sử dụng phổ biến được gọi là ASCII. Nó bao gồm các ký tự Latinh phổ biến mà bạn có thể quen thuộc nhất khi làm việc với. Đối với những ký tự này,

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
54 trả về giá trị ASCII cho ký tự
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
56

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
0

ASCII vẫn ổn khi nó đi. Nhưng có nhiều ngôn ngữ khác nhau được sử dụng trên thế giới và vô số biểu tượng và nét chữ xuất hiện trên phương tiện kỹ thuật số. Tập hợp đầy đủ các ký tự có khả năng cần được biểu diễn bằng mã máy tính vượt xa các chữ cái, số và ký hiệu Latinh thông thường mà bạn thường thấy

Unicode là một tiêu chuẩn đầy tham vọng cố gắng cung cấp mã số cho mọi ký tự có thể, trong mọi ngôn ngữ có thể, trên mọi nền tảng có thể. Python 3 hỗ trợ Unicode rộng rãi, bao gồm cả việc cho phép các ký tự Unicode trong chuỗi

Để biết thêm thông tin. Xem Unicode & Mã hóa ký tự trong Python. Hướng dẫn không gây đau đớn và Hỗ trợ Unicode của Python trong tài liệu Python

Miễn là bạn ở trong miền của các ký tự phổ biến, sẽ có rất ít sự khác biệt thực tế giữa ASCII và Unicode. Nhưng hàm

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
51 cũng sẽ trả về các giá trị số cho các ký tự Unicode

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
2

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
58

Trả về một giá trị ký tự cho số nguyên đã cho

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
50 làm ngược lại với
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
51. Cho trước một giá trị số
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
38,
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
58 trả về một chuỗi đại diện cho ký tự tương ứng với
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
38

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
9

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
50 cũng xử lý các ký tự Unicode

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
1

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
65

Trả về độ dài của một chuỗi

Với

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
52, bạn có thể kiểm tra độ dài chuỗi Python.
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
65 trả về số ký tự trong
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
6

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
69

Trả về một chuỗi đại diện của một đối tượng

Hầu như bất kỳ đối tượng nào trong Python đều có thể được hiển thị dưới dạng chuỗi.

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
69 trả về chuỗi đại diện của đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
71

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
0

Loại bỏ các quảng cáo

Lập chỉ mục chuỗi

Thông thường trong các ngôn ngữ lập trình, các mục riêng lẻ trong một tập hợp dữ liệu được sắp xếp có thể được truy cập trực tiếp bằng cách sử dụng chỉ mục số hoặc giá trị khóa. Quá trình này được gọi là lập chỉ mục

Trong Python, các chuỗi được sắp xếp thứ tự các chuỗi dữ liệu ký tự và do đó có thể được lập chỉ mục theo cách này. Có thể truy cập các ký tự riêng lẻ trong một chuỗi bằng cách chỉ định tên chuỗi theo sau là một số trong dấu ngoặc vuông [

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
72]

Lập chỉ mục chuỗi trong Python là không dựa trên. ký tự đầu tiên trong chuỗi có chỉ số

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
73, ký tự tiếp theo có chỉ số
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
74, v.v. Chỉ số của ký tự cuối cùng sẽ là độ dài của chuỗi trừ đi một

Ví dụ: sơ đồ các chỉ số của chuỗi

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
75 sẽ trông như thế này

Chỉ số chuỗi

Các ký tự riêng lẻ có thể được truy cập theo chỉ mục như sau

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
1

Cố gắng lập chỉ mục ngoài phần cuối của chuỗi dẫn đến lỗi

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
2

Chỉ mục chuỗi cũng có thể được chỉ định bằng số âm, trong trường hợp đó, việc lập chỉ mục xảy ra từ cuối chuỗi trở lại.

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
76 đề cập đến ký tự cuối cùng,
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
77 ký tự thứ hai đến cuối cùng, v.v. Đây là sơ đồ tương tự hiển thị cả chỉ số dương và âm trong chuỗi
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
75

Chỉ số chuỗi dương và âm

Dưới đây là một số ví dụ về lập chỉ mục tiêu cực

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
3

Cố gắng lập chỉ mục với các số âm ngoài phần đầu của chuỗi dẫn đến lỗi

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
4

Đối với bất kỳ chuỗi không trống nào, cả

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37,
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
80 và
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
81 đều trả về ký tự cuối cùng. Không có bất kỳ chỉ mục nào có ý nghĩa đối với một chuỗi rỗng

cắt chuỗi

Python cũng cho phép một dạng cú pháp lập chỉ mục trích xuất các chuỗi con từ một chuỗi, được gọi là cắt chuỗi. Nếu

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 là một chuỗi, một biểu thức có dạng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
83 trả về phần của
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 bắt đầu với vị trí
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
85 và cho đến nhưng không bao gồm vị trí
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
38

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
5

Nhớ lại. Các chỉ số chuỗi dựa trên số không. Ký tự đầu tiên trong chuỗi có chỉ số

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
73. Điều này áp dụng cho cả lập chỉ mục tiêu chuẩn và cắt lát

Một lần nữa, chỉ mục thứ hai xác định ký tự đầu tiên không được bao gồm trong kết quả—ký tự

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
88 [
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
89] trong ví dụ trên. Điều đó có vẻ hơi không trực quan, nhưng nó tạo ra kết quả này có ý nghĩa. biểu thức
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
83 sẽ trả về một chuỗi con có độ dài
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
91 ký tự, trong trường hợp này là
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
92

Nếu bạn bỏ qua chỉ mục đầu tiên, lát cắt sẽ bắt đầu ở đầu chuỗi. Do đó,

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
93 và
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
94 là tương đương

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
6

Tương tự, nếu bạn bỏ qua chỉ mục thứ hai như trong

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
95, lát cắt sẽ kéo dài từ chỉ mục đầu tiên cho đến hết chuỗi. Đây là một thay thế hay, ngắn gọn cho
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
96 rườm rà hơn

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
7

Đối với bất kỳ chuỗi

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 và bất kỳ số nguyên
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
38 [
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
99],
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
400 sẽ bằng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
8

Bỏ qua cả hai chỉ số trả về toàn bộ chuỗi gốc. Theo đúng nghĩa đen. Nó không phải là một bản sao, nó là một tham chiếu đến chuỗi gốc

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
9

Nếu chỉ mục đầu tiên trong một lát cắt lớn hơn hoặc bằng chỉ mục thứ hai, Python sẽ trả về một chuỗi rỗng. Đây là một cách khó hiểu khác để tạo ra một chuỗi trống, trong trường hợp bạn đang tìm kiếm một chuỗi

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
40

Các chỉ số tiêu cực cũng có thể được sử dụng với cắt lát.

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
76 đề cập đến ký tự cuối cùng,
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
77 là ký tự thứ hai đến cuối cùng, v.v., giống như với lập chỉ mục đơn giản. Sơ đồ dưới đây cho thấy cách cắt chuỗi con
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
404 từ chuỗi
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
75 bằng cách sử dụng cả chỉ số dương và âm

Cắt chuỗi với các chỉ số tích cực và tiêu cực

Đây là mã Python tương ứng

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
41

Loại bỏ các quảng cáo

Chỉ định một Stride trong một String Slice

Có thêm một biến thể của cú pháp cắt để thảo luận. Thêm một

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
406 bổ sung và một chỉ số thứ ba chỉ định một sải chân [còn gọi là bước], cho biết có bao nhiêu ký tự cần nhảy sau khi truy xuất từng ký tự trong lát cắt

Ví dụ: đối với chuỗi

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
75, lát cắt
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
408 bắt đầu bằng ký tự đầu tiên và kết thúc bằng ký tự cuối cùng [toàn bộ chuỗi] và mọi ký tự thứ hai đều bị bỏ qua. Điều này được thể hiện trong sơ đồ sau

Lập chỉ mục chuỗi với Stride

Tương tự,

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
409 chỉ định một lát cắt bắt đầu bằng ký tự thứ hai [chỉ mục
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
74] và kết thúc bằng ký tự cuối cùng, và một lần nữa, giá trị sải chân
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
411 khiến mọi ký tự khác bị bỏ qua

Lập chỉ mục chuỗi khác với Stride

Mã REPL minh họa được hiển thị ở đây

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
42

Như với bất kỳ phép cắt nào, chỉ số đầu tiên và thứ hai có thể được bỏ qua và mặc định tương ứng với các ký tự đầu tiên và cuối cùng

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
43

Bạn cũng có thể chỉ định giá trị sải chân âm, trong trường hợp đó, Python sẽ lùi lại qua chuỗi. Trong trường hợp đó, chỉ số bắt đầu/đầu tiên phải lớn hơn chỉ số kết thúc/thứ hai

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
44

Trong ví dụ trên,

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
412 có nghĩa là “bắt đầu từ ký tự cuối cùng và lùi lại bởi
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
411, cho đến nhưng không bao gồm ký tự đầu tiên. ”

Khi bạn lùi lại, nếu chỉ số thứ nhất và thứ hai bị bỏ qua, giá trị mặc định sẽ bị đảo ngược theo cách trực quan. chỉ mục đầu tiên mặc định ở cuối chuỗi và chỉ mục thứ hai mặc định ở đầu. Đây là một ví dụ

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
45

Đây là một mô hình phổ biến để đảo ngược một chuỗi

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
46

Nội suy các biến thành một chuỗi

Trong Python phiên bản 3. 6, một cơ chế định dạng chuỗi mới đã được giới thiệu. Tính năng này được đặt tên chính thức là Formatted String Literal, nhưng thường được gọi bằng biệt danh f-string

Khả năng định dạng được cung cấp bởi chuỗi f rất rộng và sẽ không được trình bày chi tiết đầy đủ tại đây. Nếu muốn tìm hiểu thêm, bạn có thể xem bài viết Real Python Python 3’s f-Strings. Cú pháp định dạng chuỗi được cải thiện [Hướng dẫn]. Ngoài ra còn có một hướng dẫn về Đầu ra được định dạng xuất hiện sau trong loạt bài này để tìm hiểu sâu hơn về chuỗi f

Một tính năng đơn giản của f-string mà bạn có thể bắt đầu sử dụng ngay là nội suy biến. Bạn có thể chỉ định một tên biến trực tiếp trong một chuỗi ký tự f và Python sẽ thay thế tên đó bằng giá trị tương ứng

Ví dụ: giả sử bạn muốn hiển thị kết quả của phép tính số học. Bạn có thể làm điều này bằng một câu lệnh

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
414 đơn giản, phân tách các giá trị số và chuỗi ký tự bằng dấu phẩy

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
47

Nhưng điều này là cồng kềnh. Để thực hiện điều tương tự bằng cách sử dụng chuỗi f

  • Chỉ định chữ thường
    ['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
    415 hoặc chữ hoa
    ['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
    416 ngay trước dấu ngoặc kép mở đầu của chuỗi ký tự. Điều này cho Python biết đó là chuỗi f thay vì chuỗi tiêu chuẩn
  • Chỉ định bất kỳ biến nào được nội suy trong dấu ngoặc nhọn [
    ['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
    417]

Viết lại bằng chuỗi f, ví dụ trên trông gọn gàng hơn nhiều

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
48

Bất kỳ cơ chế trích dẫn nào trong số ba cơ chế trích dẫn của Python đều có thể được sử dụng để xác định chuỗi f

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
49

Loại bỏ các quảng cáo

sửa đổi chuỗi

Tóm lại, bạn không thể. Chuỗi là một trong những kiểu dữ liệu mà Python coi là bất biến, nghĩa là không thể thay đổi. Trên thực tế, tất cả các kiểu dữ liệu bạn đã thấy cho đến nay đều là bất biến. [Python cung cấp các kiểu dữ liệu có thể thay đổi, như bạn sẽ sớm thấy. ]

Một tuyên bố như thế này sẽ gây ra một lỗi

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
00

Trên thực tế, thực sự không cần phải sửa đổi nhiều chuỗi. Bạn thường có thể dễ dàng thực hiện những gì mình muốn bằng cách tạo một bản sao của chuỗi gốc có thay đổi mong muốn tại chỗ. Có rất nhiều cách để làm điều này trong Python. Đây là một khả năng

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
01

Ngoài ra còn có một phương thức chuỗi tích hợp để thực hiện điều này

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
02

Đọc tiếp để biết thêm thông tin về các phương thức chuỗi tích hợp

Các phương thức chuỗi tích hợp

Bạn đã học trong hướng dẫn về Biến trong Python rằng Python là một ngôn ngữ hướng đối tượng cao. Mỗi mục dữ liệu trong chương trình Python là một đối tượng

Bạn cũng đã quen thuộc với các chức năng. các thủ tục có thể gọi được mà bạn có thể gọi để thực hiện các tác vụ cụ thể

Phương thức tương tự như hàm. Một phương thức là một loại thủ tục có thể gọi được chuyên biệt được liên kết chặt chẽ với một đối tượng. Giống như một hàm, một phương thức được gọi để thực hiện một tác vụ riêng biệt, nhưng nó được gọi trên một đối tượng cụ thể và có kiến ​​thức về đối tượng đích của nó trong quá trình thực thi

Cú pháp gọi một phương thức trên một đối tượng như sau

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
03

Điều này gọi phương thức

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
418 trên đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
71.
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
420 chỉ định các đối số được truyền cho phương thức [nếu có]

Bạn sẽ khám phá nhiều hơn nữa về việc định nghĩa và gọi các phương thức sau này trong phần thảo luận về lập trình hướng đối tượng. Hiện tại, mục tiêu là trình bày một số phương thức tích hợp được sử dụng phổ biến hơn mà Python hỗ trợ để thao tác trên các đối tượng chuỗi

Trong các định nghĩa phương thức sau đây, các đối số được chỉ định trong ngoặc vuông [______772] là tùy chọn

Chuyển đổi trường hợp

Các phương thức trong nhóm này thực hiện chuyển đổi trường hợp trên chuỗi mục tiêu

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
422

Viết hoa chuỗi mục tiêu

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
422 trả về một bản sao của
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 với ký tự đầu tiên được chuyển thành chữ hoa và tất cả các ký tự khác được chuyển thành chữ thường

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
04

Các ký tự không phải là bảng chữ cái không thay đổi

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
05

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
425

Chuyển đổi các ký tự chữ cái thành chữ thường

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
425 trả về một bản sao của
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 với tất cả các ký tự chữ cái được chuyển thành chữ thường

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
06

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
428

Trường hợp hoán đổi của các ký tự chữ cái

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
428 trả về một bản sao của
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 với các ký tự chữ hoa được chuyển thành chữ thường và ngược lại

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
07

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
431

Chuyển đổi chuỗi mục tiêu thành "trường hợp tiêu đề. ”

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
431 trả về một bản sao của
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 trong đó chữ cái đầu tiên của mỗi từ được chuyển đổi thành chữ hoa và các chữ cái còn lại là chữ thường

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
08

Phương pháp này sử dụng một thuật toán khá đơn giản. Nó không cố gắng phân biệt giữa các từ quan trọng và không quan trọng, và nó không xử lý các dấu nháy đơn, sở hữu hoặc từ viết tắt một cách duyên dáng

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
09

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
434

Chuyển đổi các ký tự chữ cái thành chữ hoa

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
434 trả về một bản sao của
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 với tất cả các ký tự chữ cái được chuyển thành chữ hoa

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
20

Tìm và thay thế

Các phương thức này cung cấp các phương tiện khác nhau để tìm kiếm chuỗi mục tiêu cho một chuỗi con đã chỉ định

Mỗi phương thức trong nhóm này hỗ trợ các đối số

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
437 và
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
438 tùy chọn. Chúng được hiểu là để cắt chuỗi. hành động của phương thức được giới hạn ở phần của chuỗi đích bắt đầu từ vị trí ký tự
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
437 và tiến tới nhưng không bao gồm vị trí ký tự
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
438. Nếu
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
437 được chỉ định nhưng
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
438 thì không, phương pháp này sẽ áp dụng cho phần của chuỗi mục tiêu từ
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
437 đến hết chuỗi

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
444

Đếm số lần xuất hiện của một chuỗi con trong chuỗi đích

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
445 trả về số lần xuất hiện không chồng lấp của chuỗi con
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
446 trong
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
21

Số lượng được giới hạn ở số lần xuất hiện trong chuỗi con được chỉ định bởi

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
437 và
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
438, nếu chúng được chỉ định

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
22

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
450

Xác định xem chuỗi mục tiêu có kết thúc bằng một chuỗi con đã cho hay không

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
451 trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 nếu
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 kết thúc bằng
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
454 đã chỉ định và ngược lại là
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
48

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
23

Việc so sánh được giới hạn ở chuỗi con được chỉ định bởi

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
437 và
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
438, nếu chúng được chỉ định

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
24

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
458

Tìm kiếm chuỗi mục tiêu cho một chuỗi con nhất định

Bạn có thể sử dụng

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
459 để xem liệu một chuỗi Python có chứa một chuỗi con cụ thể hay không.
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
460 trả về chỉ số thấp nhất trong
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 nơi tìm thấy chuỗi con
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
446

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
25

Phương thức này trả về

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
76 nếu không tìm thấy chuỗi con đã chỉ định

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
26

Tìm kiếm được giới hạn trong chuỗi con được chỉ định bởi

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
437 và
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
438, nếu chúng được chỉ định

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
27

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
466

Tìm kiếm chuỗi mục tiêu cho một chuỗi con nhất định

Phương pháp này giống hệt với

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
459, ngoại trừ việc nó đưa ra một ngoại lệ nếu không tìm thấy
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
446 thay vì trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
76

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
28

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
470

Tìm kiếm chuỗi mục tiêu cho một chuỗi con nhất định bắt đầu từ cuối

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
471 trả về chỉ số cao nhất trong
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 nơi tìm thấy chuỗi con
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
446

>>>

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
29

Cũng như với

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
459, nếu không tìm thấy chuỗi con, thì trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
76

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
00

Tìm kiếm được giới hạn trong chuỗi con được chỉ định bởi

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
437 và
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
438, nếu chúng được chỉ định

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
01

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
478

Tìm kiếm chuỗi mục tiêu cho một chuỗi con nhất định bắt đầu từ cuối

Phương pháp này giống hệt với

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
479, ngoại trừ việc nó đưa ra một ngoại lệ nếu không tìm thấy
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
446 thay vì trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
76

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
02

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
482

Xác định xem chuỗi mục tiêu có bắt đầu bằng một chuỗi con đã cho hay không

Khi bạn sử dụng phương thức Python

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
483,
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
484 trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 nếu
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 bắt đầu bằng
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
454 đã chỉ định và ngược lại là
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
48

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
03

Việc so sánh được giới hạn ở chuỗi con được chỉ định bởi

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
437 và
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
438, nếu chúng được chỉ định

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
04

Phân loại nhân vật

Các phương thức trong nhóm này phân loại một chuỗi dựa trên các ký tự mà nó chứa

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
491

Xác định xem chuỗi mục tiêu có bao gồm các ký tự chữ và số hay không

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
491 trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 nếu
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 không trống và tất cả các ký tự của nó là chữ và số [một chữ cái hoặc một số] và
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
48 nếu không

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
05

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
496

Xác định xem chuỗi mục tiêu có bao gồm các ký tự chữ cái hay không

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
496 trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 nếu
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 không trống và tất cả các ký tự của nó là chữ cái, và
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
48 nếu ngược lại

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
06

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
001

Xác định xem chuỗi mục tiêu có bao gồm các ký tự chữ số hay không

Bạn có thể sử dụng phương thức

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
002 Python để kiểm tra xem chuỗi của bạn có chỉ gồm các chữ số không.
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
001 trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 nếu
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 không trống và tất cả các ký tự của nó là các chữ số và
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
48 nếu ngược lại

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
07

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
007

Xác định xem chuỗi đích có phải là mã định danh Python hợp lệ hay không

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
007 trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 nếu
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 là mã định danh Python hợp lệ theo định nghĩa ngôn ngữ và
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
48 nếu ngược lại

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
08

Ghi chú.

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
012 sẽ trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 cho một chuỗi khớp với từ khóa Python mặc dù đó không thực sự là một mã định danh hợp lệ

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
09

Bạn có thể kiểm tra xem một chuỗi có khớp với từ khóa Python hay không bằng cách sử dụng hàm có tên là

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
014, hàm này nằm trong mô-đun có tên là
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
015. Một cách có thể để làm điều này được hiển thị dưới đây

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
20

Nếu bạn thực sự muốn đảm bảo rằng một chuỗi sẽ đóng vai trò là mã định danh Python hợp lệ, bạn nên kiểm tra xem

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
012 có phải là
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 không và
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
014 có phải là
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
48 không

Xem Các gói và mô-đun Python—Giới thiệu để đọc thêm về các mô-đun Python

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
020

Xác định xem các ký tự chữ cái của chuỗi mục tiêu có phải là chữ thường hay không

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
020 trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 nếu
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 không trống và tất cả các ký tự chữ cái chứa trong đó đều là chữ thường và nếu không thì
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
48. Các ký tự không phải là bảng chữ cái được bỏ qua

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
21

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
025

Xác định xem chuỗi mục tiêu có bao gồm toàn bộ các ký tự có thể in được hay không

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
025 trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 nếu
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 trống hoặc tất cả các ký tự chữ cái chứa trong đó đều có thể in được. Nó trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
48 nếu
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 chứa ít nhất một ký tự không in được. Các ký tự không phải là bảng chữ cái được bỏ qua

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
22

Ghi chú. Đây là phương thức duy nhất của

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
031 trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 nếu
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 là một chuỗi rỗng. Tất cả những cái khác trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
48 cho một chuỗi rỗng

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
035

Xác định xem chuỗi mục tiêu có bao gồm các ký tự khoảng trắng hay không

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
035 trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 nếu
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 không trống và tất cả các ký tự đều là ký tự khoảng trắng và
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
48 nếu ngược lại

Các ký tự khoảng trắng thường gặp nhất là khoảng trắng

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
040, tab
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
041 và dòng mới
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
042

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
23

Tuy nhiên, có một vài ký tự ASCII khác đủ điều kiện là khoảng trắng và nếu bạn tính đến các ký tự Unicode, thì có khá nhiều ký tự ngoài đó

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
24

[

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
043 và
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
044 là các chuỗi thoát cho các ký tự Trả về Vận chuyển và Nguồn cấp dữ liệu Biểu mẫu ASCII;
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
045 là chuỗi thoát cho Không gian Bốn-Em-Em Unicode. ]

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
046

Xác định xem chuỗi mục tiêu có phải là tiêu đề không

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
046 trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 nếu
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 không trống, ký tự chữ cái đầu tiên của mỗi từ là chữ hoa và tất cả các ký tự chữ cái khác trong mỗi từ là chữ thường. Nó trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
48 nếu không

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
25

Ghi chú. Đây là cách tài liệu Python mô tả

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
051, trong trường hợp bạn thấy điều này trực quan hơn. “Các ký tự chữ hoa chỉ có thể theo sau các ký tự không có chữ cái và các ký tự chữ thường chỉ có các ký tự có chữ hoa. ”

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
052

Xác định xem các ký tự chữ cái của chuỗi mục tiêu có phải là chữ hoa hay không

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
052 trả về
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
47 nếu
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 không trống và tất cả các ký tự chữ cái chứa trong đó là chữ hoa và
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
48 nếu ngược lại. Các ký tự không phải là bảng chữ cái được bỏ qua

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
26

Định dạng chuỗi

Các phương thức trong nhóm này sửa đổi hoặc nâng cao định dạng của một chuỗi

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
057

Căn giữa một chuỗi trong một trường

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
058 trả về một chuỗi bao gồm
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 được căn giữa trong một trường có chiều rộng
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
060. Theo mặc định, phần đệm bao gồm ký tự khoảng trắng ASCII

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
27

Nếu đối số

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
061 tùy chọn được chỉ định, nó sẽ được sử dụng làm ký tự đệm

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
28

Nếu

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 đã tồn tại ít nhất bằng
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
060, nó sẽ được trả về không thay đổi

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
29

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
064

Mở rộng các tab trong một chuỗi

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
065 thay thế từng ký tự tab [
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
041] bằng dấu cách. Theo mặc định, các khoảng trống được điền vào giả sử tab dừng ở mỗi cột thứ tám

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
90

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
067 là một tham số từ khóa tùy chọn chỉ định các cột dừng tab thay thế

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
91

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
068

Căn trái một chuỗi trong trường

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
069 trả về một chuỗi bao gồm
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 được căn trái trong một trường có chiều rộng
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
060. Theo mặc định, phần đệm bao gồm ký tự khoảng trắng ASCII

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
92

Nếu đối số

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
061 tùy chọn được chỉ định, nó sẽ được sử dụng làm ký tự đệm

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
93

Nếu

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 đã tồn tại ít nhất bằng
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
060, nó sẽ được trả về không thay đổi

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
94

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
075

Cắt các ký tự đầu từ một chuỗi

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
076 trả về một bản sao của
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 với bất kỳ ký tự khoảng trắng nào bị xóa khỏi đầu bên trái

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
95

Nếu đối số

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
078 tùy chọn được chỉ định, thì đó là một chuỗi chỉ định bộ ký tự sẽ bị xóa

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
96

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
079

Thay thế các lần xuất hiện của một chuỗi con trong một chuỗi

Trong Python, để xóa một ký tự khỏi chuỗi, bạn có thể sử dụng phương thức Python string

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
080.
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
081 trả về một bản sao của
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 với tất cả các lần xuất hiện của chuỗi con
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
083 được thay thế bằng
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
084

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
97

Nếu đối số

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
085 tùy chọn được chỉ định, tối đa thay thế
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
085 được thực hiện, bắt đầu từ đầu bên trái của
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
98

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
088

Căn phải một chuỗi trong một trường

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
089 trả về một chuỗi bao gồm
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 được căn phải trong một trường có chiều rộng
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
060. Theo mặc định, phần đệm bao gồm ký tự khoảng trắng ASCII

>>>

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
99

Nếu đối số

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
061 tùy chọn được chỉ định, nó sẽ được sử dụng làm ký tự đệm

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
10

Nếu

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 đã tồn tại ít nhất bằng
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
060, nó sẽ được trả về không thay đổi

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
11

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
095

Cắt các ký tự theo sau từ một chuỗi

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
096 trả về một bản sao của
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 với bất kỳ ký tự khoảng trắng nào bị xóa khỏi đầu bên phải

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
12

Nếu đối số

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
078 tùy chọn được chỉ định, thì đó là một chuỗi chỉ định bộ ký tự sẽ bị xóa

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
13

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
099

Tách các ký tự từ đầu bên trái và bên phải của một chuỗi

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
200 về cơ bản tương đương với việc gọi liên tiếp
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
076 và
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
096. Không có đối số
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
078, nó sẽ loại bỏ khoảng trắng ở đầu và cuối

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
14

Như với

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
204 và
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
205, đối số tùy chọn
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
078 chỉ định bộ ký tự sẽ bị xóa

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
15

Ghi chú. Khi giá trị trả về của một phương thức chuỗi là một chuỗi khác, như thường lệ, các phương thức có thể được gọi liên tiếp bằng cách xâu chuỗi các lệnh gọi

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
16

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
207

Đệm một chuỗi ở bên trái bằng số không

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
207 trả về một bản sao của
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 được đệm bên trái với các ký tự
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
210 cho
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
060 đã chỉ định

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
17

Nếu

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 chứa một dấu hiệu ở đầu, thì nó vẫn ở cạnh trái của chuỗi kết quả sau khi các số 0 được chèn vào

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
18

Nếu

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 đã tồn tại ít nhất bằng
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
060, nó sẽ được trả về không thay đổi

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
19

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
215 hữu ích nhất cho các biểu diễn chuỗi số, nhưng Python vẫn vui vẻ sẽ không đệm một chuỗi không phải là

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
60

Chuyển đổi giữa chuỗi và danh sách

Các phương thức trong nhóm này chuyển đổi giữa một chuỗi và một số kiểu dữ liệu tổng hợp bằng cách dán các đối tượng lại với nhau để tạo thành một chuỗi hoặc bằng cách chia một chuỗi thành nhiều phần

Các phương thức này hoạt động trên hoặc trả về các lần lặp, thuật ngữ Python chung cho một tập hợp các đối tượng tuần tự. Bạn sẽ khám phá hoạt động bên trong của iterables chi tiết hơn trong hướng dẫn sắp tới về phép lặp xác định

Nhiều phương thức trong số này trả về một danh sách hoặc một bộ. Đây là hai loại dữ liệu tổng hợp tương tự nhau, là ví dụ nguyên mẫu của các lần lặp trong Python. Chúng được đề cập trong hướng dẫn tiếp theo, vì vậy bạn sẽ sớm tìm hiểu về chúng. Cho đến lúc đó, chỉ cần nghĩ về chúng như các chuỗi giá trị. Một danh sách được đặt trong dấu ngoặc vuông [

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
72] và một bộ được đặt trong dấu ngoặc đơn [
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
217]

Với phần giới thiệu đó, chúng ta hãy xem nhóm phương thức chuỗi cuối cùng này

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
218

Nối các chuỗi từ một iterable

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
218 trả về chuỗi kết quả từ việc nối các đối tượng trong
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
220 được phân tách bằng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37

Lưu ý rằng

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
222 được gọi trên
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37, chuỗi dấu phân cách.
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
220 cũng phải là một chuỗi các đối tượng chuỗi

Một số mã mẫu sẽ giúp làm rõ. Trong ví dụ sau, dấu tách

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 là chuỗi
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
226 và
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
220 là danh sách các giá trị chuỗi

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
61

Kết quả là một chuỗi duy nhất bao gồm các đối tượng danh sách được phân tách bằng dấu phẩy

Trong ví dụ tiếp theo,

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
220 được chỉ định là một giá trị chuỗi đơn. Khi một giá trị chuỗi được sử dụng dưới dạng có thể lặp lại, nó được hiểu là danh sách các ký tự riêng lẻ của chuỗi

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
62

Như vậy, kết quả của

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
229 là một chuỗi bao gồm mỗi ký tự trong
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
230 cách nhau bởi _
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
231

Ví dụ này không thành công vì một trong các đối tượng trong

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
220 không phải là một chuỗi

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
63

Điều đó có thể được khắc phục, mặc dù

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
64

Như bạn sẽ sớm thấy, nhiều đối tượng phức hợp trong Python có thể được hiểu là các đối tượng có thể lặp lại và

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
222 đặc biệt hữu ích để tạo các chuỗi từ chúng

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
234

Chia một chuỗi dựa trên dấu phân cách

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
234 chia tách
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 ở lần xuất hiện đầu tiên của chuỗi
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
237. Giá trị trả về là một bộ ba phần bao gồm

  • Phần của
    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    37 trước
    # app.py
    
    str = "Millie,Bobby,Brown,is,Enola,Holmes"
    arr = str.split[',']
    print[arr]
    237
  • # app.py
    
    str = "Millie,Bobby,Brown,is,Enola,Holmes"
    arr = str.split[',']
    print[arr]
    237 chính nó
  • Phần của
    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    37 sau
    # app.py
    
    str = "Millie,Bobby,Brown,is,Enola,Holmes"
    arr = str.split[',']
    print[arr]
    237

Dưới đây là một vài ví dụ về

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
243 đang hoạt động

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
65

Nếu không tìm thấy

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
237 trong
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37, bộ trả về chứa
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 theo sau là hai chuỗi trống

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
66

Nhớ lại. Danh sách và bộ dữ liệu được trình bày trong hướng dẫn tiếp theo

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
247

Chia một chuỗi dựa trên dấu phân cách

Chức năng của

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
247 giống hệt như
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
234, ngoại trừ việc
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 được phân chia ở lần xuất hiện cuối cùng của
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
237 thay vì lần xuất hiện đầu tiên

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
67

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
252

Tách một chuỗi thành một danh sách các chuỗi con

Không có đối số,

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
253 chia tách
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 thành các chuỗi con được phân định bởi bất kỳ chuỗi khoảng trắng nào và trả về các chuỗi con dưới dạng danh sách

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
68

Nếu

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
237 được chỉ định, nó được sử dụng làm dấu phân cách để tách

>>>

# app.py

str = "MillieB11"
arr = list[str]
print[arr]
69

[Nếu

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
237 được chỉ định với giá trị là
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
257, thì chuỗi được phân tách bằng khoảng trắng, giống như thể
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
237 hoàn toàn không được chỉ định. ]

Khi

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
237 được cung cấp rõ ràng dưới dạng dấu phân cách, các dấu phân cách liên tiếp trong
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 được giả định để phân tách các chuỗi trống, chuỗi này sẽ được trả về

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
00

Tuy nhiên, đây không phải là trường hợp khi bỏ qua

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
237. Trong trường hợp đó, các ký tự khoảng trắng liên tiếp được kết hợp thành một dấu phân cách duy nhất và danh sách kết quả sẽ không bao giờ chứa các chuỗi trống

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
01

Nếu tham số từ khóa tùy chọn

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
262 được chỉ định, thì tối đa nhiều phần tách đó được thực hiện, bắt đầu từ đầu bên phải của
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
02

Giá trị mặc định cho

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
262 là
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
76, có nghĩa là tất cả các phân tách có thể phải được thực hiện—giống như khi bỏ qua hoàn toàn
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
262

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
03

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
267

Tách một chuỗi thành một danh sách các chuỗi con

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
268 hoạt động chính xác như
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
253, ngoại trừ việc nếu
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
262 được chỉ định, các phần tách được tính từ đầu bên trái của
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 thay vì đầu bên phải

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
04

Nếu

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
262 không được chỉ định, thì không thể phân biệt được
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
273 và
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
274

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
275

Phá vỡ một chuỗi tại ranh giới dòng

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
276 tách
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
37 thành các dòng và trả về chúng trong một danh sách. Bất kỳ ký tự hoặc chuỗi ký tự nào sau đây được coi là cấu thành ranh giới dòng

Trình tự thoát Character

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
278Newline
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
279Carriage Return
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
280Carriage Return + Line Feed
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
281 or
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
282Line Tabulation
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
283 or
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
284Form Feed
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
285File Separator
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
286Group Separator
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
287Record Separator
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
288Next Line [C1 Control Code]_______3289Unicode Line Separator0
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
29

Dưới đây là một ví dụ sử dụng một số dấu tách dòng khác nhau

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
05

Nếu các ký tự ranh giới dòng liên tiếp xuất hiện trong chuỗi, chúng được coi là phân định các dòng trống, sẽ xuất hiện trong danh sách kết quả

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
06

Nếu đối số

# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
291 tùy chọn được chỉ định và là trung thực, thì ranh giới của dòng được giữ lại trong chuỗi kết quả

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
07

Loại bỏ các quảng cáo

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 đối tượng

Đối tượng

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 là một trong những loại tích hợp cốt lõi để thao tác dữ liệu nhị phân. Một đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 là một chuỗi bất biến của các giá trị byte đơn. Mỗi phần tử trong một đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 là một số nguyên nhỏ trong khoảng từ
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
73 đến
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
297

Định nghĩa một đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 theo nghĩa đen

Một chữ

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 được định nghĩa giống như một chuỗi chữ có thêm tiền tố
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
000

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
08

Đối với chuỗi, bạn có thể sử dụng bất kỳ cơ chế trích dẫn đơn, kép hoặc ba nào

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
09

Chỉ các ký tự ASCII được cho phép trong một chữ

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29. Bất kỳ giá trị ký tự nào lớn hơn
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
002 phải được chỉ định bằng cách sử dụng chuỗi thoát thích hợp

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
10

Tiền tố

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
88 có thể được sử dụng trên một chữ
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 để vô hiệu hóa việc xử lý các chuỗi thoát, như với các chuỗi

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
11

Xác định một đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 với chức năng
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
006 tích hợp

Hàm

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
006 cũng tạo đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29. Loại đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 nào được trả về tùy thuộc vào [các] đối số được truyền cho hàm. Các hình thức có thể được hiển thị dưới đây

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
010

Tạo một đối tượng

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 từ một chuỗi

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
010 chuyển đổi chuỗi
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
013 thành đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29, sử dụng
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
015 theo
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
016 đã chỉ định

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
12

Lưu ý kỹ thuật. Ở dạng hàm

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
006 này, bắt buộc phải có đối số
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
016. “Mã hóa” đề cập đến cách mà các ký tự được dịch sang các giá trị số nguyên. Giá trị của
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
019 biểu thị Định dạng chuyển đổi Unicode UTF-8, đây là mã hóa có thể xử lý mọi ký tự Unicode có thể. UTF-8 cũng có thể được chỉ định bằng cách chỉ định
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
020,
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
021 hoặc
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
022 cho
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
016

Xem tài liệu Unicode để biết thêm thông tin. Miễn là bạn đang xử lý các ký tự dựa trên tiếng Latinh phổ biến, UTF-8 sẽ phục vụ bạn tốt

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
024

Tạo một đối tượng

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 bao gồm null [
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
026] byte

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
024 định nghĩa một đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 của
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
029 đã chỉ định, đối tượng này phải là một số nguyên dương. Đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 kết quả được khởi tạo thành null [
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
026] byte

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
13

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
032

Tạo một đối tượng

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 từ một iterable

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
032 định nghĩa một đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 từ chuỗi các số nguyên được tạo bởi
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
220.
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
220 phải là một iterable tạo ra một chuỗi các số nguyên
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
38 trong phạm vi
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
039

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
14

Loại bỏ các quảng cáo

Thao tác trên đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29

Giống như các chuỗi, các đối tượng

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 hỗ trợ các thao tác trình tự phổ biến

  • Toán tử

    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    45 và
    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    49

    >>>

    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    15

  • Toán tử nối [

    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    31] và nhân rộng [
    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    32]

    >>>

    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    16

  • Lập chỉ mục và cắt lát

    >>>

    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    17

  • Chức năng tích hợp sẵn

    >>>

    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    18

Nhiều phương thức được định nghĩa cho các đối tượng chuỗi cũng hợp lệ cho các đối tượng

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
19

Tuy nhiên, lưu ý rằng khi các toán tử và phương thức này được gọi trên đối tượng

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29, toán hạng và đối số cũng phải là đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
20

Mặc dù định nghĩa và biểu diễn đối tượng

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 dựa trên văn bản ASCII, nhưng nó thực sự hoạt động giống như một chuỗi số nguyên nhỏ bất biến trong phạm vi từ
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
73 đến
# app.py

str = "Millie,Bobby,Brown,is,Enola,Holmes"
arr = str.split[',']
print[arr]
297, bao gồm cả. Đó là lý do tại sao một phần tử từ đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 được hiển thị dưới dạng số nguyên

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
21

Tuy nhiên, một lát cắt được hiển thị dưới dạng đối tượng

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29, ngay cả khi nó chỉ dài một byte

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
22

Bạn có thể chuyển đổi một đối tượng

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 thành một danh sách các số nguyên bằng hàm
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
055 tích hợp

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
23

Số thập lục phân thường được sử dụng để chỉ định dữ liệu nhị phân vì hai chữ số thập lục phân tương ứng trực tiếp với một byte đơn. Lớp

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 hỗ trợ hai phương thức bổ sung hỗ trợ chuyển đổi sang và từ một chuỗi các chữ số thập lục phân

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
057

Trả về một đối tượng

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 được xây dựng từ một chuỗi các giá trị thập lục phân

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
057 trả về đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 là kết quả của việc chuyển đổi từng cặp chữ số thập lục phân trong
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
013 thành giá trị byte tương ứng. Các cặp chữ số thập lục phân trong
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
013 có thể tùy chọn được phân tách bằng khoảng trắng, khoảng trắng này bị bỏ qua

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
24

Ghi chú. Phương thức này là một phương thức lớp, không phải là một phương thức đối tượng. Nó được liên kết với lớp

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29, không phải đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29. Bạn sẽ tìm hiểu sâu hơn về sự khác biệt giữa các lớp, các đối tượng và các phương thức tương ứng của chúng trong các hướng dẫn sắp tới về lập trình hướng đối tượng. Hiện tại, chỉ cần quan sát rằng phương thức này được gọi trên lớp
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29, không phải trên đối tượng
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
066

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
067

Trả về một chuỗi giá trị thập lục phân từ một đối tượng

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
067 trả về kết quả chuyển đổi đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
066 thành một chuỗi các cặp chữ số thập lục phân. Nghĩa là, nó làm ngược lại với
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
072

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
25

Ghi chú. Trái ngược với

['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
072,
['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
074 là một phương thức đối tượng, không phải là một phương thức lớp. Do đó, nó được gọi trên một đối tượng của lớp
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29, không phải trên chính lớp đó

Loại bỏ các quảng cáo

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
30 đối tượng

Python hỗ trợ một loại chuỗi nhị phân khác gọi là

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
30. Đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
30 rất giống đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29, mặc dù có một số khác biệt

  • Không có cú pháp chuyên dụng nào được tích hợp trong Python để xác định một chữ

    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    30, như tiền tố
    ['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
    000 có thể được sử dụng để xác định một đối tượng
    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    29. Một đối tượng
    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    30 luôn được tạo bằng hàm tích hợp sẵn
    ['Millie', 'Bobby', 'Brown', 'is', 'Enola', 'Holmes']
    084

    >>>

    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    26

  • >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    30 đối tượng có thể thay đổi. Bạn có thể sửa đổi nội dung của đối tượng
    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    30 bằng cách lập chỉ mục và cắt

    >>>

    >>> s = 'foo.'
    
    >>> s * 4
    'foo.foo.foo.foo.'
    >>> 4 * s
    'foo.foo.foo.foo.'
    
    27

Đối tượng

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
30 cũng có thể được tạo trực tiếp từ đối tượng
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29

>>>

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
28

Sự kết luận

Hướng dẫn này cung cấp cái nhìn sâu sắc về nhiều cơ chế khác nhau mà Python cung cấp để xử lý chuỗi, bao gồm toán tử chuỗi, hàm tích hợp, lập chỉ mục, cắt và phương thức tích hợp. Bạn cũng đã được giới thiệu về các loại

>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
29 và
>>> s = 'foo.'

>>> s * 4
'foo.foo.foo.foo.'
>>> 4 * s
'foo.foo.foo.foo.'
30

Những loại này là những loại đầu tiên mà bạn đã kiểm tra có tính chất tổng hợp—được chế tạo từ một tập hợp các bộ phận nhỏ hơn. Python cung cấp một số loại tích hợp tổng hợp. Trong hướng dẫn tiếp theo, bạn sẽ khám phá hai cách sử dụng thường xuyên nhất. danh sách và bộ dữ liệu

Lấy bài kiểm tra. Kiểm tra kiến ​​thức của bạn với bài kiểm tra tương tác “Chuỗi trăn và dữ liệu ký tự” của chúng tôi. Sau khi hoàn thành, bạn sẽ nhận được điểm số để có thể theo dõi quá trình học tập của mình theo thời gian

Lấy bài kiểm tra "

« Toán tử và biểu thức trong Python

Chuỗi trong Python

Danh sách và bộ dữ liệu trong Python »

Đánh dấu là đã hoàn thành

Xem ngay Hướng dẫn này có một khóa học video liên quan do nhóm Real Python tạo. Xem nó cùng với hướng dẫn bằng văn bản để hiểu sâu hơn. Dữ liệu chuỗi và ký tự trong Python

🐍 Thủ thuật Python 💌

Nhận một Thủ thuật Python ngắn và hấp dẫn được gửi đến hộp thư đến của bạn vài ngày một lần. Không có thư rác bao giờ. Hủy đăng ký bất cứ lúc nào. Được quản lý bởi nhóm Real Python

Gửi cho tôi thủ thuật Python »

Giới thiệu về John Sturtz

John là một Pythonista cuồng nhiệt và là thành viên của nhóm hướng dẫn Real Python

» Thông tin thêm về John

Mỗi hướng dẫn tại Real Python được tạo bởi một nhóm các nhà phát triển để nó đáp ứng các tiêu chuẩn chất lượng cao của chúng tôi. Các thành viên trong nhóm đã làm việc trong hướng dẫn này là

Đan

Joanna

Bậc thầy Kỹ năng Python trong thế giới thực Với quyền truy cập không giới hạn vào Python thực

Tham gia với chúng tôi và có quyền truy cập vào hàng nghìn hướng dẫn, khóa học video thực hành và cộng đồng các Pythonistas chuyên gia

Nâng cao kỹ năng Python của bạn »

Bậc thầy Kỹ năng Python trong thế giới thực
Với quyền truy cập không giới hạn vào Python thực

Tham gia với chúng tôi và có quyền truy cập vào hàng ngàn hướng dẫn, khóa học video thực hành và cộng đồng Pythonistas chuyên gia

Nâng cao kỹ năng Python của bạn »

Bạn nghĩ sao?

Đánh giá bài viết này

Tweet Chia sẻ Chia sẻ Email

Bài học số 1 hoặc điều yêu thích mà bạn đã học được là gì?

Mẹo bình luận. Những nhận xét hữu ích nhất là những nhận xét được viết với mục đích học hỏi hoặc giúp đỡ các sinh viên khác. Nhận các mẹo để đặt câu hỏi hay và nhận câu trả lời cho các câu hỏi phổ biến trong cổng thông tin hỗ trợ của chúng tôi

Chủ Đề