Hướng dẫn how to limit output in python - làm thế nào để giới hạn đầu ra trong python

Mô -đun

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
69 [chỉ Python 3.x] được đề xuất bởi @M0NHawk được thực hiện chính xác cho mục đích này. Đây là cách bạn sẽ sử dụng nó:

Nếu bạn ổn với giới hạn mặc định, bạn chỉ cần sử dụng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
70:default limits, you can simply use
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
70:

import reprlib

obj = [[1, 2, 3], list[range[10000]]]

print[reprlib.repr[obj]]

Output:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]

Để tùy chỉnh các giới hạn có sẵn, chỉ cần tạo một thể hiện

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
71 và đặt các thuộc tính thể hiện thích hợp:customize the available limits, simply create a
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
71 instance and set the appropriate instance attributes:

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]

Output:

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]

Nếu bạn đang xử lý các đối tượng trình tự đề cập đến chính chúng, bạn có thể sử dụng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
72 để hạn chế độ sâu đệ quy:objects that refer to themselves, you can use
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
72 to limit the recursion depth:

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]

Output:

[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]

Lưu ý rằng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
73 trả về một chuỗi, nhưng không
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74 [trừ khi bạn ở trong bảng điều khiển tương tác trong đó kết quả của mọi biểu thức bạn nhập được đánh giá và biểu diễn của nó được hiển thị].

Để gán đầu ra của hàm in [] cho một biến: Xóa cuộc gọi cho hàm và gán đối số bạn đã chuyển để in [] cho biến. Hàm in [] chuyển đổi giá trị được cung cấp thành một chuỗi, in nó thành sys.

Python Basic: Bài tập-120 với giải pháp

Viết một chương trình Python để định dạng một chuỗi được chỉ định giới hạn độ dài của chuỗi.

Giải pháp mẫu:

Mã Python:

str_num = ""
print["Original string:",str_num]
print['%.6s' % str_num]
print['%.9s' % str_num]
print['%.10s' % str_num]

Đầu ra mẫu:

Original string: 
123456
123456789

Trực quan hóa thực thi mã Python:

Công cụ sau đây trực quan hóa những gì máy tính đang làm từng bước khi nó thực hiện chương trình đã nói:

Trình chỉnh sửa mã Python:

Có một cách khác để giải quyết giải pháp này? Đóng góp mã của bạn [và nhận xét] thông qua Disqus.

Trước đây: Viết một chương trình Python để làm tròn một số dấu phẩy động đến số số thập phân được chỉ định. Write a Python program to round a floating-point number to specified number decimal places.
Next: Write a Python program to determine if variable is defined or not.

Mức độ khó của bài tập này là gì?

Kiểm tra kỹ năng lập trình của bạn với bài kiểm tra của W3Resource.

Python: Lời khuyên trong ngày

Từ điển Hiểu biết:

________số 8

  • Bài tập: Top 16 chủ đề phổ biến nhất hàng tuần
  • Bài tập SQL, Thực hành, Giải pháp - Tham gia
  • Bài tập SQL, Thực hành, Giải pháp - Quan sát phụ
  • JavaScript Basic - Bài tập, Thực hành, Giải pháp
  • Java Array: Bài tập, Thực hành, Giải pháp
  • C Bài tập lập trình, Thực hành, Giải pháp: Tuyên bố có điều kiện
  • Cơ sở dữ liệu nhân sự - Sắp xếp bộ lọc: Bài tập, Thực hành, Giải pháp
  • C Bài tập lập trình, Thực hành, Giải pháp: Chuỗi
  • Các loại dữ liệu Python: Từ điển - Bài tập, Thực hành, Giải pháp
  • Câu đố lập trình Python - Bài tập, Thực hành, Giải pháp
  • Mảng C ++: Bài tập, Thực hành, Giải pháp
  • Báo cáo và vòng lặp có điều kiện JavaScript - Bài tập, Thực hành, Giải pháp
  • Thuật toán cơ bản C# Sharp: Bài tập, Thực hành, Giải pháp
  • Python Lambda - Bài tập, Thực hành, Giải pháp
  • Python Pandas DataFrame: Bài tập, Thực hành, Giải pháp
  • Công cụ chuyển đổi
  • JavaScript: HTML Mẫu xác thực

Xem bây giờ hướng dẫn này có một khóa học video liên quan được tạo bởi nhóm Python thực sự. Xem nó cùng với hướng dẫn bằng văn bản để làm sâu sắc thêm sự hiểu biết của bạn: hàm python in []: vượt xa những điều cơ bản This tutorial has a related video course created by the Real Python team. Watch it together with the written tutorial to deepen your understanding: The Python print[] Function: Go Beyond the Basics

Nếu bạn giống như hầu hết người dùng Python, bao gồm cả tôi, thì có lẽ bạn đã bắt đầu hành trình Python của mình bằng cách tìm hiểu về

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75. Nó đã giúp bạn viết
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
76 One-Liner của riêng bạn. Bạn có thể sử dụng nó để hiển thị các tin nhắn được định dạng lên màn hình và có thể tìm thấy một số lỗi. Nhưng nếu bạn nghĩ rằng, tất cả những gì cần biết về chức năng Python, ____175, thì bạn đã bỏ lỡ rất nhiều!

Hãy đọc để tận dụng tối đa chức năng nhỏ có vẻ nhàm chán và không được đánh giá cao này. Hướng dẫn này sẽ giúp bạn tăng tốc với việc sử dụng Python

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 một cách hiệu quả. Tuy nhiên, chuẩn bị cho một lần lặn sâu khi bạn đi qua các phần. Bạn có thể ngạc nhiên bao nhiêu
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 đã cung cấp!

Đến cuối hướng dẫn này, bạn sẽ biết cách:

  • Tránh những sai lầm phổ biến với Python từ
    [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    75
  • Đối phó với Newlines, mã hóa nhân vật và bộ đệm
  • Viết văn bản vào các tệp
  • Mock
    [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    75 trong các bài kiểm tra đơn vị
  • Xây dựng giao diện người dùng nâng cao trong thiết bị đầu cuối

Nếu bạn là một người mới bắt đầu hoàn chỉnh, thì bạn sẽ được hưởng lợi nhiều nhất từ ​​việc đọc phần đầu tiên của hướng dẫn này, minh họa các yếu tố cần thiết của việc in ấn trong Python. Nếu không, hãy thoải mái bỏ qua phần đó và nhảy xung quanh khi bạn thấy phù hợp.

In một cách ngắn gọn

Hãy để nhảy vào bằng cách nhìn vào một vài ví dụ thực tế về in ấn trong Python. Đến cuối phần này, bạn sẽ biết mọi cách có thể gọi

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75. Hoặc, trong Lingo Lingo, bạn nói rằng bạn sẽ quen thuộc với chữ ký chức năng.function signature.

Gọi
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75

Ví dụ đơn giản nhất về việc sử dụng Python

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 chỉ yêu cầu một vài tổ hợp phím:

Bạn không vượt qua bất kỳ đối số nào, nhưng bạn vẫn cần đặt dấu ngoặc đơn ở cuối, điều này bảo Python thực sự thực hiện chức năng thay vì chỉ đề cập đến nó bằng tên.

Điều này sẽ tạo ra một ký tự mới vô hình, từ đó sẽ khiến một dòng trống xuất hiện trên màn hình của bạn. Bạn có thể gọi

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 nhiều lần như thế này để thêm không gian dọc. Nó giống như thể bạn đã nhấn enter trên bàn phím của mình trong một trình xử lý văn bản.Enter on your keyboard in a word processor.

Một ký tự mới là một ký tự điều khiển đặc biệt được sử dụng để chỉ ra phần cuối của một dòng [EOL]. Nó thường không có một biểu diễn rõ ràng trên màn hình, nhưng một số trình chỉnh sửa văn bản có thể hiển thị các ký tự không thể in như vậy với ít đồ họa.newline character is a special control character used to indicate the end of a line [EOL]. It usually doesn’t have a visible representation on the screen, but some text editors can display such non-printable characters with little graphics.

Từ ngữ nhân vật có phần của một người hiểu sai trong trường hợp này, bởi vì một dòng mới thường dài hơn một ký tự. Ví dụ: hệ điều hành Windows, cũng như giao thức HTTP, đại diện cho Newlines với một cặp ký tự. Đôi khi bạn cần tính đến những khác biệt đó để thiết kế các chương trình thực sự di động.

Để tìm hiểu những gì tạo thành một dòng mới trong hệ điều hành của bạn, hãy sử dụng mô-đun

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
86 tích hợp của Python.

Điều này sẽ ngay lập tức cho bạn biết rằng Windows và DOS đại diện cho Newline dưới dạng chuỗi

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
87 theo sau là
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
88:Windows and DOS represent the newline as a sequence of
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
87 followed by
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
88:

>>>

>>> import os
>>> os.linesep
'\r\n'

Trên Unix, Linux và các phiên bản gần đây của MacOS, nó có một ký tự

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
88 duy nhất:Unix, Linux, and recent versions of macOS, it’s a single
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
88 character:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
0

Trên Unix, Linux và các phiên bản gần đây của MacOS, nó có một ký tự

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
88 duy nhất:Mac OS X, however, sticks to its own “think different” philosophy by choosing yet another representation:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
1

Trên Unix, Linux và các phiên bản gần đây của MacOS, nó có một ký tự

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
88 duy nhất:escape character sequence. Such sequences allow for representing control characters, which would be otherwise invisible on screen.

Tuy nhiên, Mac OS X cổ điển gắn bó với triết lý của riêng mình về vấn đề khác nhau bằng cách chọn một đại diện khác:

  • Lưu ý cách các ký tự này xuất hiện trong chuỗi chữ. Họ sử dụng cú pháp đặc biệt với dấu gạch chéo ngược trước [
    [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    90] để biểu thị sự bắt đầu của chuỗi ký tự thoát. Các chuỗi như vậy cho phép thể hiện các ký tự điều khiển, nếu không thì vô hình trên màn hình.
    backslash
  • Hầu hết các ngôn ngữ lập trình đều đi kèm với một tập hợp các chuỗi thoát được xác định trước cho các ký tự đặc biệt như sau: backspace
  • [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    91: Backslash
    tab
  • [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    92: Backspace
    carriage return [CR]
  • [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    93: Tab
    newline, also known as line feed [LF]

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
87: Vận chuyển trở lại [CR]

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
88: Newline, còn được gọi là Line Feed [LF]ASCII character codes, you’ll see that putting a backslash in front of a character changes its meaning completely. However, not all characters allow for this–only the special ones.

Hai phần cuối gợi nhớ đến các máy đánh chữ cơ học, yêu cầu hai lệnh riêng biệt để chèn một dòng mới. Lệnh đầu tiên sẽ di chuyển cỗ xe trở lại đầu dòng hiện tại, trong khi lệnh thứ hai sẽ tiến lên cuộn sang dòng tiếp theo.

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
2

Hãy nhớ rằng, để tạo thành một chuỗi thoát chính xác, không được có khoảng trống giữa ký tự dấu gạch chéo ngược và một chữ cái!

Như bạn vừa thấy, gọi

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 mà không có đối số dẫn đến một dòng trống, là một dòng chỉ bao gồm ký tự dòng mới. Don Tiết nhầm lẫn điều này với một dòng trống, không chứa bất kỳ nhân vật nào, thậm chí không phải là dòng mới!blank line, which is a line comprised solely of the newline character. Don’t confuse this with an empty line, which doesn’t contain any characters at all, not even the newline!

Bạn có thể sử dụng các chữ Python từ Chuỗi để trực quan hóa hai điều này:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
3

Người đầu tiên là một nhân vật dài, trong khi người thứ hai không có nội dung.

Trong một kịch bản phổ biến hơn, bạn đã muốn truyền đạt một số thông báo cho người dùng cuối. Có một vài cách để đạt được điều này.

Đầu tiên, bạn có thể chuyển một chuỗi trực tiếp theo nghĩa đen đến

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
4

Điều này sẽ in thông điệp nguyên văn lên màn hình.

Chuỗi chữ trong Python có thể được đặt trong các trích dẫn đơn [

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
99] hoặc trích dẫn kép [
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
00]. Theo hướng dẫn kiểu PEP 8 chính thức, bạn chỉ nên chọn một và tiếp tục sử dụng nó một cách nhất quán. Không có sự khác biệt, trừ khi bạn cần phải làm tổ trong cái khác.
in Python can be enclosed either in single quotes [
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
99] or double quotes [
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
00]. According to the official PEP 8 style guide, you should just pick one and keep using it consistently. There’s no difference, unless you need to nest one in another.

Ví dụ, bạn có thể sử dụng các trích dẫn kép cho chữ theo nghĩa đen và cũng bao gồm các trích dẫn kép bên trong nó, bởi vì đó là sự mơ hồ đối với người phiên dịch Python:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
5

Những gì bạn muốn làm là kèm theo văn bản, trong đó có chứa hai trích dẫn, trong các trích dẫn đơn:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
6

Thủ thuật tương tự sẽ hoạt động theo cách khác:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
7

Ngoài ra, bạn có thể sử dụng các chuỗi ký tự Escape được đề cập trước đó, để làm cho Python đối xử với các trích dẫn kép nội bộ đó theo nghĩa đen như là một phần của chuỗi theo nghĩa đen:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
8

Thoát khỏi là tốt và bảnh bao, nhưng đôi khi nó có thể cản trở. Cụ thể, khi bạn cần chuỗi của mình để chứa nhiều ký tự dấu gạch chéo ngược ở dạng nghĩa đen.

Một ví dụ cổ điển là đường dẫn tệp trên Windows:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
9

Lưu ý cách mỗi nhân vật dấu gạch chéo ngược cần phải được thoát ra với một dấu gạch chéo ngược khác.

Điều này thậm chí còn nổi bật hơn với các biểu thức thông thường, nhanh chóng bị xáo trộn do sử dụng nặng các ký tự đặc biệt:

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
0

May mắn thay, bạn có thể tắt nhân vật thoát hoàn toàn với sự trợ giúp của các chữ theo chuỗi thô. Chỉ cần dành cho

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
01 hoặc
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
02 trước khi trích dẫn mở đầu, và bây giờ bạn kết thúc với điều này:

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
1

Điều đó tốt hơn nhiều, phải không?

Có một vài tiền tố khác mang lại ý nghĩa đặc biệt cho các chuỗi chữ trong Python, nhưng bạn đã giành chiến thắng vào chúng ở đây.

Cuối cùng, bạn có thể xác định các chữ số đa dòng bằng cách đặt chúng giữa

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
03 hoặc
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
04, thường được sử dụng làm tài liệu.docstrings.

Đây là một ví dụ:

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
2

Để ngăn chặn một dòng mới ban đầu, chỉ cần đặt văn bản ngay sau khi mở

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
04:

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
3

Bạn cũng có thể sử dụng dấu gạch chéo ngược để loại bỏ dòng mới:

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
4

Để loại bỏ thụt lề khỏi chuỗi nhiều dòng, bạn có thể tận dụng mô-đun

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
06 tích hợp:

>>>

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
5

Điều này sẽ chăm sóc các đoạn văn không ổn định cho bạn. Ngoài ra còn có một vài chức năng hữu ích khác trong

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
06 để căn chỉnh văn bản mà bạn tìm thấy trong một trình xử lý văn bản.

Thứ hai, bạn có thể trích xuất tin nhắn đó vào biến của chính nó với một tên có ý nghĩa để tăng cường khả năng đọc và thúc đẩy tái sử dụng mã:

>>>

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
6

Cuối cùng, bạn có thể vượt qua một biểu thức, như nối chuỗi, được đánh giá trước khi in kết quả:

>>>

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
7

Trên thực tế, có một tá cách để định dạng tin nhắn trong Python. Tôi rất khuyến khích bạn xem xét các chuỗi F, được giới thiệu trong Python 3.6, bởi vì họ cung cấp cú pháp ngắn gọn nhất của tất cả:

>>>

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
8

Hơn nữa, các chuỗi F sẽ ngăn bạn mắc một sai lầm phổ biến, đó là quên gõ các toán hạng được kết hợp. Python là một ngôn ngữ được đánh máy mạnh mẽ, điều đó có nghĩa là nó đã giành được cho phép bạn làm điều này:

>>>

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
9

Điều đó sai vì thêm số vào chuỗi không có ý nghĩa. Bạn cần chuyển đổi rõ ràng số thành chuỗi trước, để kết hợp chúng với nhau:

>>>

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
0

Trừ khi bạn tự xử lý các lỗi như vậy, trình thông dịch Python sẽ cho bạn biết về một vấn đề bằng cách hiển thị một dấu vết.

Như với bất kỳ chức năng nào, nó không quan trọng cho dù bạn vượt qua một nghĩa đen, một biến hay một biểu thức. Tuy nhiên, không giống như nhiều chức năng khác,

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 sẽ chấp nhận bất cứ điều gì bất kể loại của nó.

Cho đến nay, bạn chỉ nhìn vào chuỗi, nhưng làm thế nào về các loại dữ liệu khác? Hãy để thử các loại văn bản của các loại tích hợp khác nhau và xem những gì ra mắt:

>>>

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
1

Xem ra cho hằng số

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
09, mặc dù. Mặc dù được sử dụng để chỉ ra sự vắng mặt của một giá trị, nhưng nó sẽ hiển thị là
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
10 thay vì một chuỗi trống:

Làm thế nào để

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 biết cách làm việc với tất cả các loại khác nhau này? Chà, câu trả lời ngắn gọn là nó không có. Nó hoàn toàn gọi
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
12 phía sau hậu trường để gõ bất kỳ đối tượng nào vào một chuỗi. Sau đó, nó xử lý các chuỗi một cách thống nhất.

Sau đó trong hướng dẫn này, bạn sẽ học cách sử dụng cơ chế này để in các loại dữ liệu tùy chỉnh như các lớp của bạn.

Được rồi, bây giờ bạn có thể gọi

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 với một đối số hoặc không có bất kỳ đối số nào. Bạn biết cách in các tin nhắn cố định hoặc định dạng lên màn hình. Tiểu mục tiếp theo sẽ mở rộng trên định dạng tin nhắn một chút.

Để đạt được kết quả tương tự trong việc tạo ngôn ngữ trước đó, bạn thường muốn bỏ dấu ngoặc đơn kèm theo văn bản:

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
2

Đó là vì

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74 không phải là một chức năng hồi đó, như bạn sẽ thấy trong phần tiếp theo. Tuy nhiên, lưu ý rằng trong một số trường hợp, dấu ngoặc đơn trong Python là dự phòng. Nó sẽ gây hại khi bao gồm họ khi họ chỉ bị bỏ qua. Điều đó có nghĩa là bạn nên sử dụng câu lệnh
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74 như thể nó là một chức năng? Tuyệt đối không!

Ví dụ, dấu ngoặc đơn bao quanh một biểu thức duy nhất hoặc một chữ theo nghĩa đen là tùy chọn. Cả hai hướng dẫn tạo ra cùng một kết quả trong Python 2:

>>>

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
3

Khung tròn thực sự là một phần của biểu thức chứ không phải là câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74. Nếu biểu thức của bạn chỉ chứa một mục, thì nó như thể bạn không bao gồm các dấu ngoặc.

Mặt khác, đặt dấu ngoặc đơn xung quanh nhiều mục tạo thành một bộ phận:

>>>

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
4

Khung tròn thực sự là một phần của biểu thức chứ không phải là câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74. Nếu biểu thức của bạn chỉ chứa một mục, thì nó như thể bạn không bao gồm các dấu ngoặc.

>>>

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
5

Khung tròn thực sự là một phần của biểu thức chứ không phải là câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74. Nếu biểu thức của bạn chỉ chứa một mục, thì nó như thể bạn không bao gồm các dấu ngoặc.

Mặt khác, đặt dấu ngoặc đơn xung quanh nhiều mục tạo thành một bộ phận:

Đây là một nguồn nhầm lẫn được biết đến. Trên thực tế, bạn cũng nhận được một bộ phận bằng cách nối một dấu phẩy kéo vào vật phẩm duy nhất được bao quanh bởi dấu ngoặc đơn:

Điểm mấu chốt là bạn không nên gọi

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74 với dấu ngoặc trong Python 2. Mặc dù, hoàn toàn chính xác, bạn có thể làm việc xung quanh việc này với sự trợ giúp của nhập
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
18, mà bạn sẽ đọc thêm trong phần có liên quan.positional arguments, including zero, one, or more arguments. That’s very handy in a common case of message formatting, where you’d want to join a few elements together.

Tách nhiều đối số

>>>

Khung tròn thực sự là một phần của biểu thức chứ không phải là câu lệnh
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74. Nếu biểu thức của bạn chỉ chứa một mục, thì nó như thể bạn không bao gồm các dấu ngoặc.

Mặt khác, đặt dấu ngoặc đơn xung quanh nhiều mục tạo thành một bộ phận:

>>>

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
7

Khung tròn thực sự là một phần của biểu thức chứ không phải là câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74. Nếu biểu thức của bạn chỉ chứa một mục, thì nó như thể bạn không bao gồm các dấu ngoặc.positional arguments need to follow strictly the order imposed by the function signature:

>>>

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
8

Khung tròn thực sự là một phần của biểu thức chứ không phải là câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74. Nếu biểu thức của bạn chỉ chứa một mục, thì nó như thể bạn không bao gồm các dấu ngoặc.

Mặt khác, đặt dấu ngoặc đơn xung quanh nhiều mục tạo thành một bộ phận:

>>>

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
9

Khung tròn thực sự là một phần của biểu thức chứ không phải là câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74. Nếu biểu thức của bạn chỉ chứa một mục, thì nó như thể bạn không bao gồm các dấu ngoặc.

Mặt khác, đặt dấu ngoặc đơn xung quanh nhiều mục tạo thành một bộ phận:

>>>

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
0

Khung tròn thực sự là một phần của biểu thức chứ không phải là câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74. Nếu biểu thức của bạn chỉ chứa một mục, thì nó như thể bạn không bao gồm các dấu ngoặc.keyword arguments, which are optional since they all have default values. You can view their brief documentation by calling
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
26 from the interactive interpreter.

Mặt khác, đặt dấu ngoặc đơn xung quanh nhiều mục tạo thành một bộ phận:separator and is assigned a single space [

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
28] by default. It determines the value to join elements with.

Đây là một nguồn nhầm lẫn được biết đến. Trên thực tế, bạn cũng nhận được một bộ phận bằng cách nối một dấu phẩy kéo vào vật phẩm duy nhất được bao quanh bởi dấu ngoặc đơn:

>>>

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
1

Khung tròn thực sự là một phần của biểu thức chứ không phải là câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74. Nếu biểu thức của bạn chỉ chứa một mục, thì nó như thể bạn không bao gồm các dấu ngoặc.

>>>

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
2

Khung tròn thực sự là một phần của biểu thức chứ không phải là câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74. Nếu biểu thức của bạn chỉ chứa một mục, thì nó như thể bạn không bao gồm các dấu ngoặc.

>>>

Khung tròn thực sự là một phần của biểu thức chứ không phải là câu lệnh
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74. Nếu biểu thức của bạn chỉ chứa một mục, thì nó như thể bạn không bao gồm các dấu ngoặc.

Mặt khác, đặt dấu ngoặc đơn xung quanh nhiều mục tạo thành một bộ phận:

>>>

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
4

Khung tròn thực sự là một phần của biểu thức chứ không phải là câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74. Nếu biểu thức của bạn chỉ chứa một mục, thì nó như thể bạn không bao gồm các dấu ngoặc.

>>>

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
5

Khung tròn thực sự là một phần của biểu thức chứ không phải là câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74. Nếu biểu thức của bạn chỉ chứa một mục, thì nó như thể bạn không bao gồm các dấu ngoặc.

Mặt khác, đặt dấu ngoặc đơn xung quanh nhiều mục tạo thành một bộ phận:

>>>

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
6

Khung tròn thực sự là một phần của biểu thức chứ không phải là câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74. Nếu biểu thức của bạn chỉ chứa một mục, thì nó như thể bạn không bao gồm các dấu ngoặc.

Cuối cùng, tham số

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
27 chỉ bị ràng buộc với một ký tự. Bạn có thể tham gia các yếu tố với các chuỗi có độ dài bất kỳ:

>>>

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
7

Trong các tiểu mục sắp tới, bạn sẽ khám phá các đối số từ khóa còn lại của hàm

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75.

Để in nhiều yếu tố trong Python 2, bạn phải thả dấu ngoặc đơn xung quanh chúng, giống như trước đây:

>>>

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
8

Trong các tiểu mục sắp tới, bạn sẽ khám phá các đối số từ khóa còn lại của hàm

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75.

>>>

Trong các tiểu mục sắp tới, bạn sẽ khám phá các đối số từ khóa còn lại của hàm
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75.

Để in nhiều yếu tố trong Python 2, bạn phải thả dấu ngoặc đơn xung quanh chúng, giống như trước đây:

>>>

[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
0

Trong các tiểu mục sắp tới, bạn sẽ khám phá các đối số từ khóa còn lại của hàm

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75.

Để in nhiều yếu tố trong Python 2, bạn phải thả dấu ngoặc đơn xung quanh chúng, giống như trước đây:

Nếu bạn giữ chúng, mặt khác, bạn sẽ chuyển một phần tử tuple duy nhất cho câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74:

[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
1

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
9

Ngoài ra, không có cách nào để thay đổi bộ phân cách mặc định của các phần tử được nối trong Python 2, vì vậy một cách giải quyết là sử dụng phép nội suy chuỗi như vậy:

Đó là cách mặc định để định dạng chuỗi cho đến khi phương thức
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
38 được đặt lại từ Python 3.Ngăn chặn phá vỡ dòng
Đôi khi, bạn không muốn kết thúc thông điệp của mình bằng một dòng mới để các cuộc gọi tiếp theo đến
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 sẽ tiếp tục trên cùng một dòng. Các ví dụ cổ điển bao gồm cập nhật tiến trình của một hoạt động chạy dài hoặc nhắc nhở người dùng cho đầu vào. Trong trường hợp sau, bạn muốn người dùng nhập câu trả lời trên cùng một dòng:
Nhiều ngôn ngữ lập trình phơi bày các hàm tương tự như
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 thông qua các thư viện tiêu chuẩn của chúng, nhưng họ cho phép bạn quyết định có nên thêm một dòng mới hay không. Ví dụ: trong Java và C#, bạn có hai hàm riêng biệt, trong khi các ngôn ngữ khác yêu cầu bạn phải nối thêm
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
88 ở cuối chuỗi theo nghĩa đen.
Dưới đây là một vài ví dụ về cú pháp trong các ngôn ngữ như vậy:Ngôn ngữ
Thí dụPerl

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
42

C

  • r = reprlib.Repr[]
    r.maxlist = 4       # max elements displayed for lists
    r.maxstring = 10    # max characters displayed for strings
    
    obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']
    
    print[r.repr[obj]]
    
    43
  • C ++
  • r = reprlib.Repr[]
    r.maxlist = 4       # max elements displayed for lists
    r.maxstring = 10    # max characters displayed for strings
    
    obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']
    
    print[r.repr[obj]]
    
    44
  • Ngược lại, chức năng Python từ
    [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    75 luôn thêm
    [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    88 mà không cần hỏi, bởi vì đó là những gì bạn muốn trong hầu hết các trường hợp. Để vô hiệu hóa nó, bạn có thể tận dụng một đối số từ khóa khác,
    r = reprlib.Repr[]
    r.maxlist = 4       # max elements displayed for lists
    r.maxstring = 10    # max characters displayed for strings
    
    obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']
    
    print[r.repr[obj]]
    
    47, điều này chỉ ra những gì sẽ kết thúc dòng.
  • Về mặt ngữ nghĩa, tham số
    r = reprlib.Repr[]
    r.maxlist = 4       # max elements displayed for lists
    r.maxstring = 10    # max characters displayed for strings
    
    obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']
    
    print[r.repr[obj]]
    
    47 gần như giống hệt với
    r = reprlib.Repr[]
    r.maxlist = 4       # max elements displayed for lists
    r.maxstring = 10    # max characters displayed for strings
    
    obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']
    
    print[r.repr[obj]]
    
    27 mà bạn đã thấy trước đó:

Nó phải là một chuỗi hoặc

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
09.

Nó có thể là tùy ý dài.

[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
2

Nó có giá trị mặc định là

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
51.

[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
3

Nếu bằng

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
09, nó sẽ có hiệu ứng tương tự như giá trị mặc định.

[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
4

Nếu bằng một chuỗi trống [

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
30], thì nó sẽ triệt tiêu dòng mới.

[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
5

Bây giờ bạn đã hiểu những gì xảy ra dưới mui xe khi bạn gọi

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 mà không có tranh luận. Vì bạn không cung cấp bất kỳ đối số vị trí nào cho chức năng, nên không có gì để tham gia, và vì vậy bộ phân cách mặc định không được sử dụng. Tuy nhiên, giá trị mặc định của
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
47 vẫn được áp dụng và một dòng trống hiển thị.

[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
6

Để tắt dòng mới, bạn phải chỉ định một chuỗi trống thông qua đối số từ khóa

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
47:

[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
7

Mặc dù đây là hai cuộc gọi

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 riêng biệt, có thể thực hiện một thời gian dài, cuối cùng bạn sẽ chỉ thấy một dòng. Đầu tiên, nó sẽ trông như thế này:

[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
8

Tuy nhiên, sau cuộc gọi thứ hai đến

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75, cùng một dòng sẽ xuất hiện trên màn hình như:

[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
9

Như với

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
27, bạn có thể sử dụng
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
47 để tham gia các đoạn riêng lẻ vào một đốm văn bản lớn với một dấu phân cách tùy chỉnh. Tuy nhiên, thay vì tham gia nhiều đối số, nó sẽ nối văn bản từ mỗi cuộc gọi chức năng vào cùng một dòng:

str_num = ""
print["Original string:",str_num]
print['%.6s' % str_num]
print['%.9s' % str_num]
print['%.10s' % str_num]

0

Ba hướng dẫn này sẽ xuất ra một dòng văn bản duy nhất:

Bạn có thể trộn hai đối số từ khóa:

Bạn không chỉ nhận được một dòng văn bản duy nhất mà tất cả các mục được phân tách bằng dấu phẩy:

Không có gì để ngăn bạn sử dụng nhân vật Newline với một số phần đệm thêm xung quanh nó:

str_num = ""
print["Original string:",str_num]
print['%.6s' % str_num]
print['%.9s' % str_num]
print['%.10s' % str_num]

1

Nó sẽ in ra đoạn văn bản sau:

Như bạn có thể thấy, đối số từ khóa

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
47 sẽ chấp nhận chuỗi tùy ý.

str_num = ""
print["Original string:",str_num]
print['%.6s' % str_num]
print['%.9s' % str_num]
print['%.10s' % str_num]

2

Bạn có thể làm quen với việc in ấn ở Python, nhưng vẫn còn rất nhiều thông tin hữu ích phía trước. Trong tiểu mục sắp tới, bạn sẽ học cách đánh chặn và chuyển hướng đầu ra chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75.

Ngăn chặn một dòng phá vỡ trong Python 2 yêu cầu bạn nối một dấu phẩy kéo theo biểu thức:

In vào một tệp

Dù bạn có tin hay không,

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 không biết cách biến tin nhắn thành văn bản trên màn hình của bạn và thật lòng mà nói, nó không cần. Đó là một công việc cho các lớp mã cấp thấp hơn, hiểu byte và biết cách đẩy chúng xung quanh.

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 là một sự trừu tượng đối với các lớp này, cung cấp một giao diện thuận tiện chỉ đơn thuần là giao cho việc in thực tế cho một luồng hoặc đối tượng giống như tệp. Một luồng có thể là bất kỳ tệp nào trên đĩa của bạn, ổ cắm mạng hoặc có thể là bộ đệm trong bộ nhớ.file-like object. A stream can be any file on your disk, a network socket, or perhaps an in-memory buffer.

Ngoài ra, có ba luồng tiêu chuẩn được cung cấp bởi hệ điều hành:

  1. r = reprlib.Repr[]
    r.maxlist = 4       # max elements displayed for lists
    r.maxstring = 10    # max characters displayed for strings
    
    obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']
    
    print[r.repr[obj]]
    
    73: Đầu vào tiêu chuẩn
    standard input
  2. r = reprlib.Repr[]
    r.maxlist = 4       # max elements displayed for lists
    r.maxstring = 10    # max characters displayed for strings
    
    obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']
    
    print[r.repr[obj]]
    
    74: Đầu ra tiêu chuẩn
    standard output
  3. r = reprlib.Repr[]
    r.maxlist = 4       # max elements displayed for lists
    r.maxstring = 10    # max characters displayed for strings
    
    obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']
    
    print[r.repr[obj]]
    
    75: Lỗi tiêu chuẩn
    standard error

Đầu ra tiêu chuẩn là những gì bạn thấy trong thiết bị đầu cuối khi bạn chạy các chương trình dòng lệnh khác nhau bao gồm các tập lệnh Python của riêng bạn: is what you see in the terminal when you run various command-line programs including your own Python scripts:

str_num = ""
print["Original string:",str_num]
print['%.6s' % str_num]
print['%.9s' % str_num]
print['%.10s' % str_num]

3

Trừ khi được hướng dẫn khác,

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 sẽ mặc định viết vào đầu ra tiêu chuẩn. Tuy nhiên, bạn có thể yêu cầu hệ điều hành của mình tạm thời trao đổi
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
74 cho luồng tệp, để bất kỳ đầu ra nào kết thúc trong tệp đó thay vì màn hình:

str_num = ""
print["Original string:",str_num]
print['%.6s' % str_num]
print['%.9s' % str_num]
print['%.10s' % str_num]

4

Rằng được gọi là chuyển hướng luồng.

Lỗi tiêu chuẩn tương tự như

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
74 ở chỗ nó cũng hiển thị trên màn hình. Tuy nhiên, nó có một luồng riêng biệt, có mục đích đăng nhập các thông báo lỗi cho chẩn đoán. Bằng cách chuyển hướng một hoặc cả hai, bạn có thể giữ mọi thứ sạch sẽ.

Một số chương trình sử dụng màu khác nhau để phân biệt giữa các thông báo được in thành

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
74 và
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
75:

Chạy cửa sổ công cụ trong pycharm

Trong khi cả

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
74 và
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
75 đều chỉ viết,
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
73 chỉ đọc được. Bạn có thể nghĩ về đầu vào tiêu chuẩn là bàn phím của mình, nhưng giống như với hai cái còn lại, bạn có thể trao đổi
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
73 cho một tệp để đọc dữ liệu từ đó.

Trong Python, bạn có thể truy cập tất cả các luồng tiêu chuẩn thông qua mô-đun

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
69 tích hợp:

>>>

str_num = ""
print["Original string:",str_num]
print['%.6s' % str_num]
print['%.9s' % str_num]
print['%.10s' % str_num]

5

Như bạn có thể thấy, các giá trị được xác định trước này giống với các đối tượng giống như tệp với các thuộc tính

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
86 và
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
87 cũng như các phương thức
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
88 và
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
89 trong số nhiều phương thức khác.

Theo mặc định,

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 được liên kết với
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
91 thông qua đối số
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
92 của nó, nhưng bạn có thể thay đổi điều đó. Sử dụng đối số từ khóa đó để chỉ ra một tệp được mở ở chế độ ghi hoặc nối, để các tin nhắn đi thẳng vào nó:

str_num = ""
print["Original string:",str_num]
print['%.6s' % str_num]
print['%.9s' % str_num]
print['%.10s' % str_num]

6

Điều này sẽ làm cho mã của bạn miễn dịch với chuyển hướng truyền phát ở cấp hệ điều hành, điều này có thể hoặc không mong muốn.

Để biết thêm thông tin về việc làm việc với các tệp trong Python, bạn có thể kiểm tra đọc và ghi các tệp bằng Python [Hướng dẫn].

Lưu ý rằng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 không có quyền kiểm soát mã hóa ký tự. Nó có trách nhiệm của Stream Stream để mã hóa các chuỗi unicode thành chính xác. Trong hầu hết các trường hợp, bạn đã thắng được tự đặt mã hóa, bởi vì UTF-8 mặc định là những gì bạn muốn. Nếu bạn thực sự cần, có lẽ đối với các hệ thống kế thừa, bạn có thể sử dụng đối số
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
87 của
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
95:

str_num = ""
print["Original string:",str_num]
print['%.6s' % str_num]
print['%.9s' % str_num]
print['%.10s' % str_num]

7

Thay vì một tệp thực hiện có ở đâu đó trong hệ thống tệp của bạn, bạn có thể cung cấp một tệp giả, sẽ nằm trong bộ nhớ máy tính của bạn. Bạn sẽ sử dụng kỹ thuật này sau này để chế giễu

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 trong các bài kiểm tra đơn vị:

>>>

str_num = ""
print["Original string:",str_num]
print['%.6s' % str_num]
print['%.9s' % str_num]
print['%.10s' % str_num]

8

Như bạn có thể thấy, các giá trị được xác định trước này giống với các đối tượng giống như tệp với các thuộc tính

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
86 và
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
87 cũng như các phương thức
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
88 và
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
89 trong số nhiều phương thức khác.

Theo mặc định,

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 được liên kết với
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
91 thông qua đối số
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
92 của nó, nhưng bạn có thể thay đổi điều đó. Sử dụng đối số từ khóa đó để chỉ ra một tệp được mở ở chế độ ghi hoặc nối, để các tin nhắn đi thẳng vào nó:

str_num = ""
print["Original string:",str_num]
print['%.6s' % str_num]
print['%.9s' % str_num]
print['%.10s' % str_num]

9

Điều này sẽ làm cho mã của bạn miễn dịch với chuyển hướng truyền phát ở cấp hệ điều hành, điều này có thể hoặc không mong muốn.

Để biết thêm thông tin về việc làm việc với các tệp trong Python, bạn có thể kiểm tra đọc và ghi các tệp bằng Python [Hướng dẫn].

Lưu ý rằng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 không có quyền kiểm soát mã hóa ký tự. Nó có trách nhiệm của Stream Stream để mã hóa các chuỗi unicode thành chính xác. Trong hầu hết các trường hợp, bạn đã thắng được tự đặt mã hóa, bởi vì UTF-8 mặc định là những gì bạn muốn. Nếu bạn thực sự cần, có lẽ đối với các hệ thống kế thừa, bạn có thể sử dụng đối số
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
87 của
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
95:

>>>

Original string: 
123456
123456789

1

Như bạn có thể thấy, các giá trị được xác định trước này giống với các đối tượng giống như tệp với các thuộc tính

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
86 và
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
87 cũng như các phương thức
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
88 và
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
89 trong số nhiều phương thức khác.

Original string: 
123456
123456789

2

Theo mặc định,

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 được liên kết với
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
91 thông qua đối số
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
92 của nó, nhưng bạn có thể thay đổi điều đó. Sử dụng đối số từ khóa đó để chỉ ra một tệp được mở ở chế độ ghi hoặc nối, để các tin nhắn đi thẳng vào nó:

Original string: 
123456
123456789

3

Điều này sẽ làm cho mã của bạn miễn dịch với chuyển hướng truyền phát ở cấp hệ điều hành, điều này có thể hoặc không mong muốn.

Original string: 
123456
123456789

4

Để biết thêm thông tin về việc làm việc với các tệp trong Python, bạn có thể kiểm tra đọc và ghi các tệp bằng Python [Hướng dẫn].

Original string: 
123456
123456789

5

Lưu ý rằng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 không có quyền kiểm soát mã hóa ký tự. Nó có trách nhiệm của Stream Stream để mã hóa các chuỗi unicode thành chính xác. Trong hầu hết các trường hợp, bạn đã thắng được tự đặt mã hóa, bởi vì UTF-8 mặc định là những gì bạn muốn. Nếu bạn thực sự cần, có lẽ đối với các hệ thống kế thừa, bạn có thể sử dụng đối số
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
87 của
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
95:

Thay vì một tệp thực hiện có ở đâu đó trong hệ thống tệp của bạn, bạn có thể cung cấp một tệp giả, sẽ nằm trong bộ nhớ máy tính của bạn. Bạn sẽ sử dụng kỹ thuật này sau này để chế giễu
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 trong các bài kiểm tra đơn vị:

Nếu bạn đến điểm này, thì bạn sẽ chỉ còn lại một đối số từ khóa trong

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75, mà bạn sẽ thấy trong tiểu mục tiếp theo. Nó có lẽ ít được sử dụng nhất trong tất cả chúng. Tuy nhiên, có những lúc nó hoàn toàn cần thiết.

Hãy tưởng tượng bạn đang viết một bộ đếm thời gian đếm ngược, sẽ nối thời gian còn lại vào cùng một dòng mỗi giây:

Nỗ lực đầu tiên của bạn có thể trông giống như thế này:

Original string: 
123456
123456789

6

Miễn là biến

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
09 lớn hơn 0, mã tiếp tục nối thêm văn bản mà không có dòng mới và sau đó đi ngủ trong một giây. Cuối cùng, khi đếm ngược kết thúc, nó in
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
10 và chấm dứt dòng.

Thật bất ngờ, thay vì đếm ngược mỗi giây, chương trình không hoạt động lãng phí trong ba giây, và sau đó đột nhiên in toàn bộ dòng cùng một lúc:

Điều đó bởi vì các bộ đệm hệ điều hành tiếp theo ghi vào đầu ra tiêu chuẩn trong trường hợp này. Bạn cần biết rằng có ba loại luồng liên quan đến bộ đệm:

  1. Không bị ảnh hưởng
  2. Line-buffered
  3. Block-buffered

Không bị ảnh hưởng là tự giải thích, nghĩa là không có bộ đệm đang diễn ra và tất cả các văn bản đều có hiệu lực ngay lập tức. Một luồng đệm dòng chờ đợi trước khi bắn bất kỳ cuộc gọi I/O nào cho đến khi ngắt dòng xuất hiện ở đâu đó trong bộ đệm, trong khi đó, một buff được chặn chỉ cho phép bộ đệm lấp đầy lên một kích thước nhất định bất kể nội dung của nó. Đầu ra tiêu chuẩn là cả đệm và đệm khối, tùy thuộc vào sự kiện nào đến trước. is self-explanatory, that is, no buffering is taking place, and all writes have immediate effect. A line-buffered stream waits before firing any I/O calls until a line break appears somewhere in the buffer, whereas a block-buffered one simply allows the buffer to fill up to a certain size regardless of its content. Standard output is both line-buffered and block-buffered, depending on which event comes first.

Bộ đệm giúp giảm số lượng cuộc gọi I/O đắt tiền. Ví dụ, hãy suy nghĩ về việc gửi tin nhắn qua một mạng có độ trễ cao. Khi bạn kết nối với một máy chủ từ xa để thực thi các lệnh qua giao thức SSH, mỗi tổ hợp phím của bạn thực sự có thể tạo ra một gói dữ liệu riêng lẻ, các đơn đặt hàng có cường độ lớn hơn tải trọng của nó. Thật là một chi phí! Sẽ có ý nghĩa để đợi cho đến khi ít nhất một vài ký tự được gõ và sau đó gửi chúng lại với nhau. Đó là nơi mà bộ đệm bước vào.

Mặt khác, bộ đệm đôi khi có thể có các hiệu ứng không mong muốn như bạn vừa thấy với ví dụ đếm ngược. Để khắc phục nó, bạn chỉ có thể nói với

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 để xóa mạnh luồng mà không cần chờ một ký tự mới trong bộ đệm bằng cờ
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
12 của nó:

Original string: 
123456
123456789

7

Đó là tất cả. Việc đếm ngược của bạn sẽ hoạt động như mong đợi bây giờ, nhưng don lồng nhận lời của tôi cho nó. Đi trước và kiểm tra nó để thấy sự khác biệt.

Xin chúc mừng! Tại thời điểm này, bạn đã thấy các ví dụ về việc gọi

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 bao gồm tất cả các tham số của nó. Bạn biết mục đích của họ và khi nào nên sử dụng chúng. Hiểu chữ ký chỉ là khởi đầu, tuy nhiên. Trong các phần sắp tới, bạn sẽ thấy lý do tại sao.

Có một cách dễ dàng để xóa luồng trong Python 2, bởi vì câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74 không cho phép nó tự nó. Bạn cần phải có một tay cầm của lớp cấp thấp hơn, đây là đầu ra tiêu chuẩn và gọi trực tiếp với nó:

Original string: 
123456
123456789

8

Ngoài ra, bạn có thể vô hiệu hóa bộ đệm của các luồng tiêu chuẩn bằng cách cung cấp cờ

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
15 cho trình thông dịch Python hoặc bằng cách thiết lập biến môi trường
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
16:

Original string: 
123456
123456789

9

Lưu ý rằng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 đã được đưa vào Python 2 và được cung cấp thông qua mô -đun
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
18. Thật không may, nó không đi kèm với tham số
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
12:

>>>

>>> m = {x: x ** 2 for x in range[5]}
>>> m
{0: 0, 1: 1, 2: 4, 3: 9, 4: 16}
0

Những gì bạn thấy ở đây là một tài liệu của hàm

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75. Bạn có thể hiển thị các tài liệu của các đối tượng khác nhau trong Python bằng cách sử dụng hàm
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
21 tích hợp.docstring of the
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 function. You can display docstrings of various objects in Python using the built-in
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
21 function.

In các loại dữ liệu tùy chỉnh

Cho đến bây giờ, bạn chỉ xử lý các loại dữ liệu tích hợp như chuỗi và số, nhưng bạn sẽ thường muốn in các loại dữ liệu trừu tượng của riêng mình. Hãy để một cái nhìn về các cách khác nhau để xác định chúng.

Đối với các đối tượng đơn giản mà không có bất kỳ logic nào, có mục đích mang dữ liệu, bạn thường sẽ tận dụng

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
22, có sẵn trong thư viện tiêu chuẩn. Các bộ dữ liệu có tên có một biểu diễn văn bản gọn gàng ra khỏi hộp:

>>>

>>> m = {x: x ** 2 for x in range[5]}
>>> m
{0: 0, 1: 1, 2: 4, 3: 9, 4: 16}
1

Những gì bạn thấy ở đây là một tài liệu của hàm

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75. Bạn có thể hiển thị các tài liệu của các đối tượng khác nhau trong Python bằng cách sử dụng hàm
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
21 tích hợp.

>>> m = {x: x ** 2 for x in range[5]}
>>> m
{0: 0, 1: 1, 2: 4, 3: 9, 4: 16}
2

In các loại dữ liệu tùy chỉnh

>>>

>>> m = {x: x ** 2 for x in range[5]}
>>> m
{0: 0, 1: 1, 2: 4, 3: 9, 4: 16}
3

Những gì bạn thấy ở đây là một tài liệu của hàm

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75. Bạn có thể hiển thị các tài liệu của các đối tượng khác nhau trong Python bằng cách sử dụng hàm
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
21 tích hợp.

>>> m = {x: x ** 2 for x in range[5]}
>>> m
{0: 0, 1: 1, 2: 4, 3: 9, 4: 16}
4

In các loại dữ liệu tùy chỉnh

Cho đến bây giờ, bạn chỉ xử lý các loại dữ liệu tích hợp như chuỗi và số, nhưng bạn sẽ thường muốn in các loại dữ liệu trừu tượng của riêng mình. Hãy để một cái nhìn về các cách khác nhau để xác định chúng.

Thật đúng là việc thiết kế các loại dữ liệu bất biến là mong muốn, nhưng trong nhiều trường hợp, bạn sẽ muốn chúng cho phép thay đổi, vì vậy bạn đã quay lại với các lớp học thông thường một lần nữa.

Từ các tiểu mục trước đó, bạn đã biết rằng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 hoàn toàn gọi hàm
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
12 tích hợp để chuyển đổi các đối số vị trí của nó thành các chuỗi. Thật vậy, việc gọi
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
12 theo cách thủ công đối với một trường hợp của lớp
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
23 thông thường mang lại kết quả tương tự như in nó:

>>>

>>> m = {x: x ** 2 for x in range[5]}
>>> m
{0: 0, 1: 1, 2: 4, 3: 9, 4: 16}
5

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
12, lần lượt, tìm kiếm một trong hai phương pháp ma thuật trong thân lớp, mà bạn thường thực hiện. Nếu nó không tìm thấy một, thì nó sẽ trở lại với biểu diễn mặc định xấu xí. Những phương pháp ma thuật đó, theo thứ tự tìm kiếm:magic methods within the class body, which you typically implement. If it doesn’t find one, then it falls back to the ugly default representation. Those magic methods are, in order of search:

  1. [[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
    
    35
  2. [[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
    
    36

Cái đầu tiên được khuyến nghị trả lại một văn bản ngắn, có thể đọc được, bao gồm thông tin từ các thuộc tính có liên quan nhất. Rốt cuộc, bạn không muốn hiển thị dữ liệu nhạy cảm, chẳng hạn như mật khẩu người dùng, khi in các đối tượng.

Tuy nhiên, một cái khác nên cung cấp thông tin đầy đủ về một đối tượng, để cho phép khôi phục trạng thái của nó từ một chuỗi. Lý tưởng nhất, nó sẽ trả về mã Python hợp lệ, để bạn có thể chuyển trực tiếp đến

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
37:

>>>

>>> m = {x: x ** 2 for x in range[5]}
>>> m
{0: 0, 1: 1, 2: 4, 3: 9, 4: 16}
6

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
12, lần lượt, tìm kiếm một trong hai phương pháp ma thuật trong thân lớp, mà bạn thường thực hiện. Nếu nó không tìm thấy một, thì nó sẽ trở lại với biểu diễn mặc định xấu xí. Những phương pháp ma thuật đó, theo thứ tự tìm kiếm:

Cái đầu tiên được khuyến nghị trả lại một văn bản ngắn, có thể đọc được, bao gồm thông tin từ các thuộc tính có liên quan nhất. Rốt cuộc, bạn không muốn hiển thị dữ liệu nhạy cảm, chẳng hạn như mật khẩu người dùng, khi in các đối tượng.

Tuy nhiên, một cái khác nên cung cấp thông tin đầy đủ về một đối tượng, để cho phép khôi phục trạng thái của nó từ một chuỗi. Lý tưởng nhất, nó sẽ trả về mã Python hợp lệ, để bạn có thể chuyển trực tiếp đến

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
37:

Lưu ý rằng việc sử dụng một chức năng tích hợp khác,

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
38, luôn cố gắng gọi
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
39 trong một đối tượng, nhưng lại trở lại biểu diễn mặc định nếu nó không tìm thấy phương thức đó.

>>> m = {x: x ** 2 for x in range[5]}
>>> m
{0: 0, 1: 1, 2: 4, 3: 9, 4: 16}
7

Python cung cấp cho bạn rất nhiều tự do khi xác định các loại dữ liệu của riêng bạn nếu không có loại nào tích hợp đáp ứng nhu cầu của bạn. Một số trong số chúng, chẳng hạn như các bộ dữ liệu và các lớp dữ liệu được đặt tên, cung cấp các biểu diễn chuỗi trông tốt mà không yêu cầu bất kỳ công việc nào từ phía bạn. Tuy nhiên, đối với sự linh hoạt nhất, bạn sẽ phải xác định một lớp và ghi đè các phương thức ma thuật của nó được mô tả ở trên.

Các ngữ nghĩa của

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
40 và
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
39 đã thay đổi kể từ Python 2, nhưng bạn phải nhớ rằng các chuỗi không có gì khác hơn là các mảng byte được tôn vinh hồi đó. Để chuyển đổi các đối tượng của bạn thành Unicode thích hợp, đó là một loại dữ liệu riêng biệt, bạn phải cung cấp một phương thức ma thuật khác:
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
42.character sets. UTF-8 is the most widespread and safest encoding, while
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
47 is a special constant to express funky characters, such as
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
48, as escape sequences in plain ASCII, such as
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
49.

Ở đây, một ví dụ về cùng một lớp

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
43 trong Python 2:charset must correspond to the one used by the terminal. For example, default encoding in DOS and Windows is CP 852 rather than UTF-8, so running this can result in a
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
04 or even garbled output:

>>>

>>> m = {x: x ** 2 for x in range[5]}
>>> m
{0: 0, 1: 1, 2: 4, 3: 9, 4: 16}
8

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
12, lần lượt, tìm kiếm một trong hai phương pháp ma thuật trong thân lớp, mà bạn thường thực hiện. Nếu nó không tìm thấy một, thì nó sẽ trở lại với biểu diễn mặc định xấu xí. Những phương pháp ma thuật đó, theo thứ tự tìm kiếm:

>>>

>>> m = {x: x ** 2 for x in range[5]}
>>> m
{0: 0, 1: 1, 2: 4, 3: 9, 4: 16}
9

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
12, lần lượt, tìm kiếm một trong hai phương pháp ma thuật trong thân lớp, mà bạn thường thực hiện. Nếu nó không tìm thấy một, thì nó sẽ trở lại với biểu diễn mặc định xấu xí. Những phương pháp ma thuật đó, theo thứ tự tìm kiếm:

Cái đầu tiên được khuyến nghị trả lại một văn bản ngắn, có thể đọc được, bao gồm thông tin từ các thuộc tính có liên quan nhất. Rốt cuộc, bạn không muốn hiển thị dữ liệu nhạy cảm, chẳng hạn như mật khẩu người dùng, khi in các đối tượng.

>>>

>>> import os
>>> os.linesep
'\r\n'
0

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
12, lần lượt, tìm kiếm một trong hai phương pháp ma thuật trong thân lớp, mà bạn thường thực hiện. Nếu nó không tìm thấy một, thì nó sẽ trở lại với biểu diễn mặc định xấu xí. Những phương pháp ma thuật đó, theo thứ tự tìm kiếm:

Cái đầu tiên được khuyến nghị trả lại một văn bản ngắn, có thể đọc được, bao gồm thông tin từ các thuộc tính có liên quan nhất. Rốt cuộc, bạn không muốn hiển thị dữ liệu nhạy cảm, chẳng hạn như mật khẩu người dùng, khi in các đối tượng.

Tuy nhiên, một cái khác nên cung cấp thông tin đầy đủ về một đối tượng, để cho phép khôi phục trạng thái của nó từ một chuỗi. Lý tưởng nhất, nó sẽ trả về mã Python hợp lệ, để bạn có thể chuyển trực tiếp đến

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
37:how to use
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 quite well at this point, but knowing what it is will allow you to use it even more effectively and consciously. After reading this section, you’ll understand how printing in Python has improved over the years.

Lưu ý rằng việc sử dụng một chức năng tích hợp khác,
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
38, luôn cố gắng gọi
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
39 trong một đối tượng, nhưng lại trở lại biểu diễn mặc định nếu nó không tìm thấy phương thức đó.

Python cung cấp cho bạn rất nhiều tự do khi xác định các loại dữ liệu của riêng bạn nếu không có loại nào tích hợp đáp ứng nhu cầu của bạn. Một số trong số chúng, chẳng hạn như các bộ dữ liệu và các lớp dữ liệu được đặt tên, cung cấp các biểu diễn chuỗi trông tốt mà không yêu cầu bất kỳ công việc nào từ phía bạn. Tuy nhiên, đối với sự linh hoạt nhất, bạn sẽ phải xác định một lớp và ghi đè các phương thức ma thuật của nó được mô tả ở trên.

>>>

>>> import os
>>> os.linesep
'\r\n'
1

Các ngữ nghĩa của

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
40 và
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
39 đã thay đổi kể từ Python 2, nhưng bạn phải nhớ rằng các chuỗi không có gì khác hơn là các mảng byte được tôn vinh hồi đó. Để chuyển đổi các đối tượng của bạn thành Unicode thích hợp, đó là một loại dữ liệu riêng biệt, bạn phải cung cấp một phương thức ma thuật khác:
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
42.

>>>

>>> import os
>>> os.linesep
'\r\n'
2

Ở đây, một ví dụ về cùng một lớp

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
43 trong Python 2:redefine
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 so that it doesn’t append a trailing newline. At the same time, you wanted to rename the original function to something like
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
61:

>>>

>>> import os
>>> os.linesep
'\r\n'
3

Bây giờ bạn có hai hàm in riêng biệt giống như trong ngôn ngữ lập trình Java. Bạn cũng sẽ xác định các chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 tùy chỉnh trong phần chế giễu sau này. Ngoài ra, lưu ý rằng bạn sẽ không thể ghi đè lên
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 ngay từ đầu nếu đó là một chức năng.

Mặt khác,

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 không phải là một chức năng theo nghĩa toán học, bởi vì nó không trả về bất kỳ giá trị có ý nghĩa nào khác ngoài
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
09 ẩn:

>>>

>>> import os
>>> os.linesep
'\r\n'
4

Trên thực tế, các chức năng như vậy là các thủ tục hoặc chương trình con mà bạn gọi để đạt được một số loại tác dụng phụ, cuối cùng là một sự thay đổi của một trạng thái toàn cầu. Trong trường hợp của

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75, tác dụng phụ đó đang hiển thị một thông báo về đầu ra tiêu chuẩn hoặc ghi vào một tệp.

Bởi vì

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 là một hàm, nó có một chữ ký được xác định rõ với các thuộc tính đã biết. Bạn có thể nhanh chóng tìm thấy tài liệu của nó bằng cách sử dụng trình soạn thảo bạn chọn, mà không cần phải nhớ một số cú pháp kỳ lạ để thực hiện một nhiệm vụ nhất định.documentation using the editor of your choice, without having to remember some weird syntax for performing a certain task.

Bên cạnh đó, các chức năng dễ dàng hơn để mở rộng. Việc thêm một tính năng mới vào một chức năng cũng dễ dàng như việc thêm một đối số từ khóa khác, trong khi việc thay đổi ngôn ngữ để hỗ trợ tính năng mới đó thì cồng kềnh hơn nhiều. Hãy nghĩ về chuyển hướng luồng hoặc xả đệm, ví dụ.extend. Adding a new feature to a function is as easy as adding another keyword argument, whereas changing the language to support that new feature is much more cumbersome. Think of stream redirection or buffer flushing, for example.

Một lợi ích khác của

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 là một hàm là khả năng kết hợp. Các chức năng được gọi là các đối tượng hạng nhất hoặc các công dân hạng nhất trong Python, đó là một cách lạ mắt để nói rằng chúng có giá trị giống như chuỗi hoặc số. Bằng cách này, bạn có thể gán một hàm cho một biến, chuyển nó cho một hàm khác hoặc thậm chí trả lại một hàm khác.
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 là khác nhau về vấn đề này. Chẳng hạn, bạn có thể tận dụng nó để tiêm phụ thuộc:composability. Functions are so-called first-class objects or first-class citizens in Python, which is a fancy way of saying they’re values just like strings or numbers. This way, you can assign a function to a variable, pass it to another function, or even return one from another.
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 isn’t different in this regard. For instance, you can take advantage of it for dependency injection:

>>> import os
>>> os.linesep
'\r\n'
5

Ở đây, tham số

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
70 cho phép bạn tiêm chức năng gọi lại, mặc định là
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 nhưng có thể có thể gọi được. Trong ví dụ này, in hoàn toàn bị vô hiệu hóa bằng cách thay thế
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 bằng một chức năng giả không làm gì cả.

Thành phần cho phép bạn kết hợp một vài chức năng thành một loại mới cùng loại. Hãy cùng xem điều này trong hành động bằng cách chỉ định hàm

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
73 tùy chỉnh in vào luồng lỗi tiêu chuẩn và tiền tố tất cả các thông báo với mức nhật ký đã cho:

>>>

>>> import os
>>> os.linesep
'\r\n'
6

Chức năng tùy chỉnh này sử dụng các chức năng một phần để đạt được hiệu ứng mong muốn. Nó có một khái niệm nâng cao mượn từ mô hình lập trình chức năng, vì vậy bây giờ bạn không cần phải đi sâu vào chủ đề đó. Tuy nhiên, nếu bạn quan tâm đến chủ đề này, tôi khuyên bạn nên xem mô -đun

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
74.partial functions to achieve the desired effect. It’s an advanced concept borrowed from the functional programming paradigm, so you don’t need to go too deep into that topic for now. However, if you’re interested in this topic, I recommend taking a look at the
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
74 module.

Không giống như các câu lệnh, các hàm là giá trị. Điều đó có nghĩa là bạn có thể trộn chúng với các biểu thức, đặc biệt là các biểu thức lambda. Thay vì xác định chức năng toàn diện để thay thế

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 bằng, bạn có thể tạo biểu thức Lambda ẩn danh gọi nó:expressions, in particular, lambda expressions. Instead of defining a full-blown function to replace
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 with, you can make an anonymous lambda expression that calls it:

>>>

>>> import os
>>> os.linesep
'\r\n'
7

Tuy nhiên, vì một biểu thức Lambda được xác định tại chỗ, nên không có cách nào để đề cập đến nó ở nơi khác trong mã.

Một loại biểu thức khác là biểu thức điều kiện ternary:

>>>

>>> import os
>>> os.linesep
'\r\n'
8

Python có cả tuyên bố có điều kiện và biểu thức có điều kiện. Cái sau được đánh giá thành một giá trị duy nhất có thể được gán cho một biến hoặc được truyền đến một hàm. Trong ví dụ trên, bạn có thể quan tâm đến hiệu ứng phụ chứ không phải giá trị, đánh giá thành

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
09, vì vậy bạn chỉ cần bỏ qua nó.

Như bạn có thể thấy, các chức năng cho phép một giải pháp thanh lịch và mở rộng, phù hợp với phần còn lại của ngôn ngữ. Trong tiểu mục tiếp theo, bạn sẽ khám phá ra cách không có

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 như một chức năng gây ra rất nhiều đau đầu.

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74 là một tuyên bố trong Python 2

Một tuyên bố là một hướng dẫn có thể gợi lên một tác dụng phụ khi được thực thi nhưng không bao giờ đánh giá đến một giá trị. Nói cách khác, bạn sẽ không thể in một câu lệnh hoặc gán nó cho một biến như sau:statement is an instruction that may evoke a side-effect when executed but never evaluates to a value. In other words, you wouldn’t be able to print a statement or assign it to a variable like this:

>>> import os
>>> os.linesep
'\r\n'
9

Đó là một lỗi cú pháp trong Python 2.

Dưới đây là một vài ví dụ nữa về các tuyên bố trong Python:

  • Bài tập:
    [[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
    
    79
    [[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
    
    79
  • Có điều kiện:
    [[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
    
    80
    [[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
    
    80
  • Vòng lặp:
    [[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
    
    81
    [[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
    
    81
  • Khẳng định:
    [[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
    
    82
    :
    [[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
    
    82

Các câu lệnh thường bao gồm các từ khóa dành riêng như

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
80,
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
84 hoặc
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74 có ý nghĩa cố định trong ngôn ngữ. Bạn có thể sử dụng chúng để đặt tên cho các biến của bạn hoặc các ký hiệu khác. Đó là lý do tại sao việc xác định lại hoặc chế giễu tuyên bố
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74 không thể xảy ra trong Python 2. Bạn đã bị mắc kẹt với những gì bạn nhận được.

Hơn nữa, bạn có thể in từ các chức năng ẩn danh, bởi vì các câu lệnh được chấp nhận trong các biểu thức Lambda:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
00

Cú pháp của tuyên bố

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74 là mơ hồ. Đôi khi bạn có thể thêm dấu ngoặc đơn xung quanh tin nhắn và chúng hoàn toàn tùy chọn:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
01

Vào những lúc khác, họ thay đổi cách in thông báo:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
02

Sự kết hợp chuỗi có thể tăng

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
88 do các loại không tương thích, ví dụ như bạn phải xử lý thủ công: ví dụ:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
03

So sánh điều này với mã tương tự trong Python 3, tận dụng trình tự giải nén:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
04

Có bất kỳ đối số từ khóa nào cho các nhiệm vụ phổ biến như xả bộ đệm hoặc chuyển hướng luồng. Thay vào đó, bạn cần nhớ cú pháp kỳ quặc. Ngay cả chức năng

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
21 tích hợp cũng hữu ích liên quan đến tuyên bố
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
05

Trailing Newline Remove không hoạt động hoàn toàn đúng, bởi vì nó thêm một không gian không mong muốn. Bạn có thể soạn thảo nhiều câu

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74 cùng nhau, và trên hết, bạn phải siêng năng hơn về mã hóa ký tự.

Danh sách các vấn đề tiếp tục. Nếu bạn tò mò, bạn có thể quay trở lại phần trước và tìm kiếm các giải thích chi tiết hơn về cú pháp trong Python 2.

Tuy nhiên, bạn có thể giảm thiểu một số vấn đề với cách tiếp cận đơn giản hơn nhiều. Hóa ra chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 đã được đưa ra để giảm bớt việc di chuyển sang Python 3. Bạn có thể nhập nó từ một mô -đun
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
18 đặc biệt, hiển thị một lựa chọn các tính năng ngôn ngữ được phát hành trong các phiên bản Python sau này.

Để kích hoạt chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 trong Python 2, bạn cần thêm câu lệnh nhập này khi bắt đầu mã nguồn của mình:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
06

Từ bây giờ tuyên bố

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74 không còn nữa, nhưng bạn có chức năng
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 theo ý của bạn. Lưu ý rằng nó không phải là chức năng giống như trong Python 3, bởi vì nó thiếu đối số từ khóa
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
12, nhưng phần còn lại của các đối số là như nhau.

Ngoài ra, nó không dành cho bạn việc quản lý mã hóa nhân vật đúng cách.

Ở đây, một ví dụ về việc gọi hàm

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 trong Python 2:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
07

Bây giờ bạn có một ý tưởng về cách in trong Python phát triển và quan trọng nhất là hiểu tại sao những thay đổi không tương thích lạc hậu này là cần thiết. Biết điều này chắc chắn sẽ giúp bạn trở thành một lập trình viên Python tốt hơn.

In với phong cách

Nếu bạn nghĩ rằng in chỉ là về ánh sáng pixel trên màn hình, thì về mặt kỹ thuật, bạn sẽ đúng. Tuy nhiên, có nhiều cách để làm cho nó trông mát mẻ. Trong phần này, bạn sẽ tìm ra cách định dạng các cấu trúc dữ liệu phức tạp, thêm màu sắc và các trang trí khác, xây dựng giao diện, sử dụng hoạt hình và thậm chí phát âm thanh với văn bản!

Các cấu trúc dữ liệu lồng nhau đẹp mắt

Ngôn ngữ máy tính cho phép bạn biểu diễn dữ liệu cũng như mã thực thi theo cách có cấu trúc. Tuy nhiên, không giống như Python, hầu hết các ngôn ngữ đều cho bạn rất nhiều tự do trong việc sử dụng khoảng trắng và định dạng. Điều này có thể hữu ích, ví dụ như trong nén, nhưng đôi khi nó dẫn đến mã không dễ đọc.

In đẹp là về việc tạo ra một phần dữ liệu hoặc mã trông hấp dẫn hơn đối với mắt người để có thể hiểu dễ dàng hơn. Điều này được thực hiện bằng cách thụt các dòng nhất định, chèn các dòng mới, sắp xếp lại các yếu tố, v.v.

Python đi kèm với mô-đun

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
99 trong thư viện tiêu chuẩn của nó, điều này sẽ giúp bạn in các cấu trúc dữ liệu lớn đẹp mà không phù hợp với một dòng. Bởi vì nó in một cách thân thiện hơn với con người, nhiều công cụ thay thế phổ biến, bao gồm Jupyterlab và Ipython, sử dụng nó theo mặc định thay cho hàm
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 thông thường.

Nếu bạn không quan tâm đến việc không có quyền truy cập vào chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 gốc, thì bạn có thể thay thế nó bằng
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
02 trong mã của mình bằng cách sử dụng đổi tên nhập khẩu:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
08

Cá nhân, tôi muốn có cả hai chức năng trong tầm tay, vì vậy tôi đã sử dụng một cái gì đó như

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
03 như một bí danh ngắn:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
09

Thoạt nhìn, có hầu như không có sự khác biệt nào giữa hai chức năng và trong một số trường hợp, hầu như không có: không có gì:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
10

Điều đó bởi vì

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
02 gọi
[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
38 thay vì thông thường
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
12 để đúc loại, để bạn có thể đánh giá đầu ra của nó dưới dạng mã Python nếu bạn muốn. Sự khác biệt trở nên rõ ràng khi bạn bắt đầu cho nó ăn các cấu trúc dữ liệu phức tạp hơn:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
11

Chức năng áp dụng định dạng hợp lý để cải thiện khả năng đọc, nhưng bạn có thể tùy chỉnh nó hơn nữa với một vài tham số. Ví dụ: bạn có thể giới hạn một hệ thống phân cấp được lồng sâu bằng cách hiển thị dấu chấm lửng dưới một cấp độ nhất định:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
12

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 thông thường cũng sử dụng các hình elip nhưng để hiển thị các cấu trúc dữ liệu đệ quy, tạo thành một chu kỳ, để tránh lỗi Overflow Lỗi:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
13

Tuy nhiên,

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
02 rõ ràng hơn về nó bằng cách bao gồm danh tính duy nhất của một đối tượng tự tham chiếu:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
14

Phần tử cuối cùng trong danh sách là cùng một đối tượng với toàn bộ danh sách.

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
02 tự động sắp xếp các khóa từ điển cho bạn trước khi in, cho phép so sánh nhất quán. Khi bạn so sánh các chuỗi, bạn thường không quan tâm đến một thứ tự cụ thể của các thuộc tính nối tiếp. Dù sao, nó luôn luôn tốt nhất để so sánh từ điển thực tế trước khi tuần tự hóa.

Từ điển thường đại diện cho dữ liệu JSON, được sử dụng rộng rãi trên Internet. Để nối tiếp chính xác một từ điển thành chuỗi định dạng JSON hợp lệ, bạn có thể tận dụng mô-đun

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
10. Nó cũng có khả năng in đẹp:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
15

Tuy nhiên, lưu ý rằng bạn cần phải tự mình in in, bởi vì nó không phải là thứ mà bạn thường muốn làm. Tương tự, mô -đun

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
99 có hàm
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
12 bổ sung trả về một chuỗi, trong trường hợp bạn phải làm một cái gì đó khác ngoài việc in nó.

Đáng ngạc nhiên, chữ ký của

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
02 không giống như hàm
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75. Bạn thậm chí có thể vượt qua nhiều hơn một đối số vị trí, cho thấy nó tập trung vào các cấu trúc dữ liệu in.

Thêm màu sắc với trình tự thoát ANSI

Khi máy tính cá nhân trở nên tinh vi hơn, chúng có đồ họa tốt hơn và có thể hiển thị nhiều màu sắc hơn. Tuy nhiên, các nhà cung cấp khác nhau đã có ý tưởng riêng về thiết kế API để kiểm soát nó. Điều đó đã thay đổi một vài thập kỷ trước khi người dân tại Viện Tiêu chuẩn Quốc gia Hoa Kỳ quyết định thống nhất nó bằng cách xác định mã thoát ANSI.

Hầu hết các trình giả lập thiết bị đầu cuối ngày nay hỗ trợ tiêu chuẩn này ở một mức độ nào đó. Cho đến gần đây, hệ điều hành Windows là một ngoại lệ đáng chú ý. Do đó, nếu bạn muốn tính di động tốt nhất, hãy sử dụng thư viện

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
15 trong Python. Nó dịch mã ANSI sang các đối tác thích hợp của chúng trong Windows trong khi vẫn giữ nguyên chúng trong các hệ điều hành khác.

Để kiểm tra xem thiết bị đầu cuối của bạn có hiểu một tập hợp con của chuỗi thoát ANSI không, ví dụ, liên quan đến màu sắc, bạn có thể thử sử dụng lệnh sau:

Thiết bị đầu cuối mặc định của tôi trên Linux cho biết nó có thể hiển thị 256 màu riêng biệt, trong khi Xterm chỉ cung cấp cho tôi 8. Lệnh sẽ trả về một số âm nếu màu sắc không được hỗ trợ.

Trình tự thoát ANSI giống như một ngôn ngữ đánh dấu cho thiết bị đầu cuối. Trong HTML, bạn làm việc với các thẻ, chẳng hạn như

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
16 hoặc
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
17, để thay đổi cách các yếu tố nhìn trong tài liệu. Các thẻ này được trộn lẫn với nội dung của bạn, nhưng chúng không thể nhìn thấy bản thân. Tương tự, các mã Escape won đã xuất hiện trong thiết bị đầu cuối miễn là nó nhận ra chúng. Mặt khác, họ sẽ xuất hiện ở dạng theo nghĩa đen như thể bạn đang xem nguồn gốc của một trang web.

Đúng như tên gọi của nó, một chuỗi phải bắt đầu với ký tự ESC không thể in, có giá trị ASCII là 27, đôi khi được ký hiệu là

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
18 trong thập lục phân hoặc
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
19 trong octal. Bạn có thể sử dụng các chữ số Python để nhanh chóng xác minh nó thực sự là cùng một số:Esc character, whose ASCII value is 27, sometimes denoted as
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
18 in hexadecimal or
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
19 in octal. You may use Python number literals to quickly verify it’s indeed the same number:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
16

Tuy nhiên, lưu ý rằng bạn cần phải tự mình in in, bởi vì nó không phải là thứ mà bạn thường muốn làm. Tương tự, mô -đun

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
99 có hàm
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
12 bổ sung trả về một chuỗi, trong trường hợp bạn phải làm một cái gì đó khác ngoài việc in nó.

Đáng ngạc nhiên, chữ ký của

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
02 không giống như hàm
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75. Bạn thậm chí có thể vượt qua nhiều hơn một đối số vị trí, cho thấy nó tập trung vào các cấu trúc dữ liệu in.

Thêm màu sắc với trình tự thoát ANSIKhi máy tính cá nhân trở nên tinh vi hơn, chúng có đồ họa tốt hơn và có thể hiển thị nhiều màu sắc hơn. Tuy nhiên, các nhà cung cấp khác nhau đã có ý tưởng riêng về thiết kế API để kiểm soát nó. Điều đó đã thay đổi một vài thập kỷ trước khi người dân tại Viện Tiêu chuẩn Quốc gia Hoa Kỳ quyết định thống nhất nó bằng cách xác định mã thoát ANSI.Hầu hết các trình giả lập thiết bị đầu cuối ngày nay hỗ trợ tiêu chuẩn này ở một mức độ nào đó. Cho đến gần đây, hệ điều hành Windows là một ngoại lệ đáng chú ý. Do đó, nếu bạn muốn tính di động tốt nhất, hãy sử dụng thư viện
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
15 trong Python. Nó dịch mã ANSI sang các đối tác thích hợp của chúng trong Windows trong khi vẫn giữ nguyên chúng trong các hệ điều hành khác.
Để kiểm tra xem thiết bị đầu cuối của bạn có hiểu một tập hợp con của chuỗi thoát ANSI không, ví dụ, liên quan đến màu sắc, bạn có thể thử sử dụng lệnh sau: Thiết bị đầu cuối mặc định của tôi trên Linux cho biết nó có thể hiển thị 256 màu riêng biệt, trong khi Xterm chỉ cung cấp cho tôi 8. Lệnh sẽ trả về một số âm nếu màu sắc không được hỗ trợ.Trình tự thoát ANSI giống như một ngôn ngữ đánh dấu cho thiết bị đầu cuối. Trong HTML, bạn làm việc với các thẻ, chẳng hạn như
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
16 hoặc
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
17, để thay đổi cách các yếu tố nhìn trong tài liệu. Các thẻ này được trộn lẫn với nội dung của bạn, nhưng chúng không thể nhìn thấy bản thân. Tương tự, các mã Escape won đã xuất hiện trong thiết bị đầu cuối miễn là nó nhận ra chúng. Mặt khác, họ sẽ xuất hiện ở dạng theo nghĩa đen như thể bạn đang xem nguồn gốc của một trang web.
Đúng như tên gọi của nó, một chuỗi phải bắt đầu với ký tự ESC không thể in, có giá trị ASCII là 27, đôi khi được ký hiệu là
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
18 trong thập lục phân hoặc
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
19 trong octal. Bạn có thể sử dụng các chữ số Python để nhanh chóng xác minh nó thực sự là cùng một số:
Ngoài ra, bạn có thể có được nó với chuỗi thoát
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
20 trong vỏ:
Đúng như tên gọi của nó, một chuỗi phải bắt đầu với ký tự ESC không thể in, có giá trị ASCII là 27, đôi khi được ký hiệu là
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
18 trong thập lục phân hoặc
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
19 trong octal. Bạn có thể sử dụng các chữ số Python để nhanh chóng xác minh nó thực sự là cùng một số:
Ngoài ra, bạn có thể có được nó với chuỗi thoát
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
20 trong vỏ:
Trình tự thoát ANSI phổ biến nhất có dạng sau:Yếu tố
Sự mô tảThí dụThoát ra

Nhân vật thoát hiểm không thể innumeric code can be one or more numbers separated with a semicolon, while the character code is just one letter. Their specific meaning is defined by the ANSI standard. For example, to reset all formatting, you would type one of the following commands, which use the code zero and the letter

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
26:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
17

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
21

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
18

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
22

Mở khung vuông

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
19

Mã số

một hoặc nhiều số được phân tách bằng

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
24

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
25

Mã ký tự

Thư viết hoa hoặc chữ thường

Làm thế nào về việc làm một trò chơi rắn retro? Hãy để tạo ra một trình giả lập Snake Python:

Đầu tiên, bạn cần nhập mô -đun

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
30. Vì nó sửa đổi trạng thái của một thiết bị đầu cuối đang chạy, nên điều quan trọng là phải xử lý các lỗi và khôi phục lại trạng thái trước đó. Bạn có thể làm điều này theo cách thủ công, nhưng thư viện đi kèm với một trình bao bọc thuận tiện cho chức năng chính của bạn:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
20

Lưu ý, hàm phải chấp nhận tham chiếu đến đối tượng màn hình, còn được gọi là

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
32, mà bạn sẽ sử dụng sau để thiết lập bổ sung.

Nếu bạn chạy chương trình này ngay bây giờ, bạn đã giành được bất kỳ hiệu ứng nào, vì nó chấm dứt ngay lập tức. Tuy nhiên, bạn có thể thêm một độ trễ nhỏ để có một cái nhìn lén:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
21

Lần này, màn hình hoàn toàn trống rỗng trong một giây, nhưng con trỏ vẫn nhấp nháy. Để ẩn nó, chỉ cần gọi một trong các hàm cấu hình được xác định trong mô -đun:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
22

Hãy để xác định con rắn là danh sách các điểm trong tọa độ màn hình:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
23

Đầu của con rắn luôn là yếu tố đầu tiên trong danh sách, trong khi đuôi là phần cuối cùng. Hình dạng ban đầu của con rắn nằm ngang, bắt đầu từ góc trên cùng bên trái của màn hình và hướng sang phải. Trong khi tọa độ y của nó ở lại bằng 0, tọa độ X của nó giảm từ đầu đến đuôi.

Để vẽ con rắn, bạn sẽ bắt đầu với cái đầu và sau đó làm theo các đoạn còn lại. Mỗi phân đoạn mang theo tọa độ

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
33, vì vậy bạn có thể giải nén chúng:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
24

Một lần nữa, nếu bạn chạy mã này ngay bây giờ, nó đã giành được hiển thị bất cứ thứ gì, bởi vì bạn phải làm mới rõ ràng màn hình sau đó:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
25

Bạn muốn di chuyển con rắn theo một trong bốn hướng, có thể được định nghĩa là vectơ. Cuối cùng, hướng sẽ thay đổi để đáp ứng với một phím kẽ mũi tên, do đó bạn có thể kết nối nó với các mã khóa của thư viện:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
26

Làm thế nào để một con rắn di chuyển? Nó chỉ ra rằng chỉ có đầu của nó thực sự di chuyển đến một vị trí mới, trong khi tất cả các phân khúc khác thay đổi về phía nó. Trong mỗi bước, hầu hết tất cả các phân đoạn vẫn giữ nguyên, ngoại trừ đầu và đuôi. Giả sử con rắn đang phát triển, bạn có thể tháo đuôi và chèn một đầu mới ở đầu danh sách:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
27

Để có được các tọa độ mới của đầu, bạn cần thêm vectơ hướng vào nó. Tuy nhiên, việc thêm các bộ dữ liệu trong Python dẫn đến một tuple lớn hơn thay vì tổng đại số của các thành phần vectơ tương ứng. Một cách để khắc phục điều này là bằng cách sử dụng các hàm

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
34,
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
35 và
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
36 tích hợp.

Hướng sẽ thay đổi trên một phím phím, vì vậy bạn cần gọi

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
37 để có được mã khóa được nhấn. Tuy nhiên, nếu phím được nhấn không tương ứng với các phím mũi tên được xác định trước đó là các phím từ điển, thì hướng giành được thay đổi:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
28

Tuy nhiên, theo mặc định,

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
37 là một cuộc gọi chặn sẽ ngăn con rắn di chuyển trừ khi có phím kẽ. Do đó, bạn cần thực hiện cuộc gọi không chặn bằng cách thêm một cấu hình khác:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
29

Bạn gần như đã hoàn thành, nhưng ở đó, chỉ còn một điều cuối cùng. Nếu bây giờ bạn lặp lại mã này, con rắn sẽ dường như đang phát triển thay vì di chuyển. Điều đó bởi vì bạn phải xóa màn hình một cách rõ ràng trước mỗi lần lặp.

Cuối cùng, đây là tất cả những gì bạn cần để chơi trò chơi rắn trong Python:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
30

Điều này chỉ đơn thuần là làm trầy xước bề mặt của các khả năng mà mô -đun

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
30 mở ra. Bạn có thể sử dụng nó để phát triển trò chơi như thế này hoặc các ứng dụng hướng đến doanh nghiệp.

Sống nó với hình ảnh động tuyệt vời

Hoạt hình không chỉ có thể làm cho giao diện người dùng trở nên hấp dẫn hơn đối với mắt mà còn cải thiện trải nghiệm người dùng tổng thể. Ví dụ, khi bạn cung cấp phản hồi sớm cho người dùng, họ sẽ biết liệu chương trình của bạn có còn hoạt động hay không, nếu thời gian để giết nó.

Để làm động văn bản trong thiết bị đầu cuối, bạn phải có thể tự do di chuyển con trỏ xung quanh. Bạn có thể làm điều này với một trong các công cụ được đề cập trước đây, đó là mã thoát ANSI hoặc thư viện

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
30. Tuy nhiên, tôi đã muốn cho bạn thấy một cách thậm chí đơn giản hơn.

Nếu hoạt hình có thể bị hạn chế với một dòng văn bản, thì bạn có thể quan tâm đến hai chuỗi ký tự thoát đặc biệt:

  • Trở về vận chuyển:
    [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    87
    [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    87
  • Backspace:
    [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    92
    [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    92

Cái đầu tiên di chuyển con trỏ sang đầu dòng, trong khi cái thứ hai di chuyển nó chỉ một ký tự sang trái. Cả hai đều làm việc theo cách không phá hủy mà không ghi đè văn bản mà đã được viết.

Hãy cùng xem một vài ví dụ.

Bạn thường muốn hiển thị một số loại bánh xe quay để chỉ ra một công việc đang tiến triển mà không biết chính xác thời gian còn lại để hoàn thành:spinning wheel to indicate a work in progress without knowing exactly how much time’s left to finish:

Nhiều công cụ dòng lệnh sử dụng thủ thuật này trong khi tải xuống dữ liệu qua mạng. Bạn có thể tạo một hình ảnh động chuyển động dừng thực sự đơn giản từ một chuỗi các nhân vật sẽ đạp xe theo kiểu vòng tròn:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
31

Vòng lặp có được ký tự tiếp theo để in, sau đó di chuyển con trỏ sang đầu dòng và ghi đè lên bất cứ thứ gì trước đây mà không cần thêm một dòng mới. Bạn không muốn có thêm không gian giữa các đối số vị trí, vì vậy đối số phân tách phải trống. Ngoài ra, hãy chú ý việc sử dụng các chuỗi thô của Python, do các ký tự dấu gạch chéo ngược có mặt trong nghĩa đen.

Khi bạn biết tỷ lệ phần trăm hoàn thành thời gian hoặc nhiệm vụ còn lại, thì bạn có thể hiển thị một thanh tiến trình hoạt hình:

Đầu tiên, bạn cần tính toán số lượng hashtag để hiển thị và số lượng không gian trống cần chèn. Tiếp theo, bạn xóa dòng và xây dựng thanh từ đầu:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
32

Như trước đây, mỗi yêu cầu để cập nhật lặp lại toàn bộ dòng.

Tạo ra âm thanh với
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75

Nếu bạn đủ tuổi để nhớ máy tính có loa PC, thì bạn cũng phải nhớ âm thanh tiếng bíp đặc biệt của chúng, thường được sử dụng để chỉ ra các vấn đề về phần cứng. Họ hầu như không thể tạo ra bất kỳ tiếng ồn nào hơn thế, nhưng các trò chơi video có vẻ tốt hơn rất nhiều với nó.

Hôm nay bạn vẫn có thể tận dụng loa nhỏ này, nhưng rất có thể máy tính xách tay của bạn đã không đi kèm với một. Trong trường hợp như vậy, bạn có thể kích hoạt mô phỏng chuông đầu cuối trong vỏ của mình, để phát ra âm thanh cảnh báo hệ thống được phát.terminal bell emulation in your shell, so that a system warning sound is played instead.

Đi trước và nhập lệnh này để xem liệu thiết bị đầu cuối của bạn có thể phát âm thanh không:

Điều này thường sẽ in văn bản, nhưng cờ

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
44 cho phép giải thích các lần thoát khỏi dấu gạch chéo ngược. Như bạn có thể thấy, có một chuỗi lối thoát chuyên dụng
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
45, viết tắt của cảnh báo cảnh báo, điều đó xuất hiện một nhân vật chuông đặc biệt. Một số thiết bị đầu cuối tạo ra một âm thanh bất cứ khi nào họ nhìn thấy nó.

Tương tự, bạn có thể in nhân vật này bằng Python. Có lẽ trong một vòng lặp để tạo thành một số loại giai điệu. Mặc dù nó chỉ có một ghi chú duy nhất, bạn vẫn có thể thay đổi chiều dài tạm dừng giữa các trường hợp liên tiếp. Đó có vẻ như là một món đồ chơi hoàn hảo cho phát lại mã Morse!

Các quy tắc như sau:

  • Các chữ cái được mã hóa với một chuỗi các ký hiệu DOT [·] và Dash [ -].dot [·] and dash [–] symbols.
  • Một dấu chấm là một đơn vị thời gian.dot is one unit of time.
  • Một dấu gạch ngang là ba đơn vị thời gian.dash is three units of time.
  • Các biểu tượng riêng lẻ trong một chữ cái cách nhau một đơn vị thời gian.symbols in a letter are spaced one unit of time apart.
  • Biểu tượng của hai chữ cái liền kề được đặt cách nhau ba đơn vị thời gian.letters are spaced three units of time apart.
  • Biểu tượng của hai từ liền kề được đặt cách nhau bảy đơn vị thời gian.words are spaced seven units of time apart.

Theo các quy tắc đó, bạn có thể là một tín hiệu SOS một tín hiệu vô thời hạn theo cách sau:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
33

Trong Python, bạn có thể thực hiện nó chỉ trong mười dòng mã:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
34

Có lẽ bạn thậm chí có thể tiến thêm một bước và tạo một công cụ dòng lệnh để dịch văn bản thành mã Morse? Dù bằng cách nào, tôi hy vọng bạn có thể vui vẻ với điều này!

Chế giễu Python
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 trong các bài kiểm tra đơn vị

Ngày nay, nó dự kiến ​​rằng bạn vận chuyển mã đáp ứng các tiêu chuẩn chất lượng cao. Nếu bạn khao khát trở thành một chuyên gia, bạn phải học cách kiểm tra mã của bạn.

Kiểm tra phần mềm đặc biệt quan trọng trong các ngôn ngữ được đánh máy động, chẳng hạn như Python, mà don don có một trình biên dịch để cảnh báo bạn về những sai lầm rõ ràng. Các khiếm khuyết có thể tìm đường đến môi trường sản xuất và không hoạt động trong một thời gian dài, cho đến một ngày đó khi một nhánh mã cuối cùng được thực thi.

Chắc chắn, bạn có lớp lót, trình kiểm tra nhập và các công cụ khác để phân tích mã tĩnh để hỗ trợ bạn. Nhưng họ đã giành chiến thắng cho bạn biết liệu chương trình của bạn có thực hiện những gì mà nó phải làm ở cấp độ kinh doanh hay không.

Vì vậy, bạn nên thử nghiệm

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75? Rốt cuộc, nó là một chức năng tích hợp mà phải trải qua một bộ thử nghiệm toàn diện. Tuy nhiên, điều bạn muốn kiểm tra là liệu mã của bạn có gọi
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 vào đúng thời điểm với các tham số dự kiến ​​hay không. Rằng được biết đến như một hành vi.behavior.

Bạn có thể kiểm tra các hành vi bằng cách chế giễu các đối tượng hoặc chức năng thực. Trong trường hợp này, bạn muốn chế giễu

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 để ghi lại và xác minh các yêu cầu của nó.

Chế giễu trong Python có thể được thực hiện gấp đôi. Đầu tiên, bạn có thể đi theo con đường truyền thống của các ngôn ngữ được gõ tĩnh bằng cách sử dụng tiêm phụ thuộc. Điều này đôi khi có thể yêu cầu bạn thay đổi mã được kiểm tra, điều này luôn luôn có thể nếu mã được xác định trong thư viện bên ngoài:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
35

Đây là ví dụ tương tự tôi đã sử dụng trong một phần trước để nói về thành phần chức năng. Về cơ bản, nó cho phép thay thế

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 bằng chức năng tùy chỉnh của cùng một giao diện. Để kiểm tra xem nó có in đúng thông báo không, bạn phải chặn nó bằng cách tiêm chức năng bị chế giễu:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
36

Gọi cái giả này làm cho nó lưu thông báo cuối cùng trong một thuộc tính mà bạn có thể kiểm tra sau, ví dụ trong một câu lệnh

[[1, 2, 3], [0, 1, 2, 3, ...], 'lo...ing', 'a', ...]
82.

Trong một giải pháp thay thế một chút, thay vì thay thế toàn bộ chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 bằng trình bao bọc tùy chỉnh, bạn có thể chuyển hướng đầu ra tiêu chuẩn đến một luồng ký tự giống như tệp trong bộ nhớ:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
37

Lần này, chức năng gọi rõ ràng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75, nhưng nó phơi bày tham số ____292 của nó với thế giới bên ngoài.

Tuy nhiên, một cách chế giễu các đối tượng pythonic hơn tận dụng mô-đun

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
55 tích hợp, sử dụng một kỹ thuật gọi là vá khỉ. Cái tên xúc phạm này bắt nguồn từ nó là một bản hack bẩn thỉu mà bạn có thể dễ dàng tự bắn vào chân mình. Nó ít thanh lịch hơn so với tiêm phụ thuộc nhưng chắc chắn nhanh chóng và thuận tiện.

Những gì việc vá khỉ làm là thay đổi thực hiện động trong thời gian chạy. Một sự thay đổi như vậy có thể nhìn thấy trên toàn cầu, vì vậy nó có thể có những hậu quả không mong muốn. Tuy nhiên, trong thực tế, việc vá lỗi chỉ ảnh hưởng đến mã trong suốt thời gian thực hiện thử nghiệm.

Để chế giễu

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 trong trường hợp thử nghiệm, bạn thường sử dụng trình trang trí
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
57 và chỉ định mục tiêu để vá bằng cách đề cập đến nó với một tên đủ điều kiện, bao gồm cả tên mô -đun:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
38

Điều này sẽ tự động tạo chế độ giả cho bạn và đưa nó vào chức năng thử nghiệm. Tuy nhiên, bạn cần tuyên bố rằng chức năng kiểm tra của bạn chấp nhận một chế độ giả ngay bây giờ. Đối tượng giả cơ bản có rất nhiều phương thức và thuộc tính hữu ích để xác minh hành vi.

Bạn có nhận thấy điều gì đặc biệt về đoạn mã đó không?

Mặc dù tiêm một chế độ giả vào chức năng, nhưng bạn không gọi nó trực tiếp, mặc dù bạn có thể. Điều đó đã được tiêm giả chỉ được sử dụng để đưa ra các xác nhận sau đó và có thể để chuẩn bị bối cảnh trước khi chạy thử nghiệm.

Trong cuộc sống thực, chế giễu giúp cô lập mã được kiểm tra bằng cách loại bỏ các phụ thuộc như kết nối cơ sở dữ liệu. Bạn hiếm khi gọi Mocks trong một bài kiểm tra, bởi vì điều đó không có ý nghĩa gì. Thay vào đó, nó có các đoạn mã khác gọi là giả của bạn một cách gián tiếp mà không biết nó.

Ở đây, điều đó có nghĩa là gì:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
39

Mã được kiểm tra là một hàm in một lời chào. Mặc dù nó có một chức năng khá đơn giản, nhưng bạn có thể thử nghiệm nó một cách dễ dàng vì nó không trả lại giá trị. Nó có một tác dụng phụ.

Để loại bỏ tác dụng phụ đó, bạn cần phải chế giễu sự phụ thuộc. Việc vá lỗi cho phép bạn tránh thực hiện các thay đổi đối với chức năng ban đầu, có thể vẫn là bất khả tri về

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75. Nó nghĩ rằng nó gọi là
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75, nhưng trên thực tế, nó gọi là một chế giễu mà bạn có thể kiểm soát hoàn toàn.

Có nhiều lý do để thử nghiệm phần mềm. Một trong số đó là tìm kiếm lỗi. Khi bạn viết các bài kiểm tra, bạn thường muốn loại bỏ chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75, ví dụ, bằng cách chế giễu nó. Tuy nhiên, nghịch lý là chức năng tương tự có thể giúp bạn tìm thấy lỗi trong quá trình gỡ lỗi liên quan đến bạn sẽ đọc trong phần tiếp theo.

Bạn có thể có con khỉ vá bản tuyên bố

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74 trong Python 2, bạn cũng không thể tiêm nó như một sự phụ thuộc. Tuy nhiên, bạn có một vài tùy chọn khác:

  • Sử dụng chuyển hướng luồng.
  • Bản vá đầu ra tiêu chuẩn được xác định trong mô -đun
    r = reprlib.Repr[]
    r.maxlist = 4       # max elements displayed for lists
    r.maxstring = 10    # max characters displayed for strings
    
    obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']
    
    print[r.repr[obj]]
    
    69.
  • Nhập
    [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    75 từ mô -đun
    r = reprlib.Repr[]
    r.maxlist = 4       # max elements displayed for lists
    r.maxstring = 10    # max characters displayed for strings
    
    obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']
    
    print[r.repr[obj]]
    
    18.

Hãy để kiểm tra chúng từng cái một.

Chuyển hướng luồng gần giống với ví dụ bạn đã thấy trước đó:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
40

Chỉ có hai sự khác biệt. Đầu tiên, cú pháp chuyển hướng luồng sử dụng chevron [

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
65] thay vì đối số
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
92. Sự khác biệt khác là nơi
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
67 được xác định. Bạn có thể nhập nó từ một mô -đun
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
67 có tên tương tự hoặc
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
69 để triển khai nhanh hơn.

Việc vá đầu ra tiêu chuẩn từ mô -đun

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
69 chính xác là những gì nó nghe, nhưng bạn cần phải biết một vài gotchas:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
41

Trước hết, hãy nhớ cài đặt mô -đun

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
55 vì nó không có sẵn trong thư viện tiêu chuẩn trong Python 2.

Thứ hai, câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74 gọi phương thức
r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
89 bên dưới trên đối tượng bị chế giễu thay vì gọi chính đối tượng. Đó là lý do tại sao bạn sẽ chạy các xác nhận chống lại
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
74.

Cuối cùng, một câu lệnh

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
74 không phải lúc nào cũng tương ứng với một cuộc gọi đến
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
76. Trên thực tế, bạn sẽ thấy nhân vật Newline được viết riêng.

Tùy chọn cuối cùng bạn có là nhập

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 từ
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
78 và vá nó:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
42

Một lần nữa, nó gần giống với Python 3, nhưng hàm

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 được xác định trong mô -đun
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
80 thay vì
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
81.

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 gỡ lỗi

Trong phần này, bạn sẽ xem các công cụ có sẵn để gỡ lỗi trong Python, bắt đầu từ hàm

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 khiêm tốn, thông qua mô -đun
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
84, đến một trình gỡ lỗi hoàn toàn. Sau khi đọc nó, bạn sẽ có thể đưa ra quyết định có giáo dục về việc nào trong số họ là phù hợp nhất trong một tình huống nhất định.

Truy tìm

Còn được gọi là gỡ lỗi in hoặc gỡ lỗi Caveman, nó là hình thức gỡ lỗi cơ bản nhất. Mặc dù hơi lỗi thời, nhưng nó vẫn mạnh mẽ và có việc sử dụng.print debugging or caveman debugging, it’s the most basic form of debugging. While a little bit old-fashioned, it’s still powerful and has its uses.

Ý tưởng là đi theo con đường thực hiện chương trình cho đến khi nó dừng đột ngột hoặc đưa ra kết quả không chính xác, để xác định hướng dẫn chính xác với một vấn đề. Bạn làm điều đó bằng cách chèn các câu lệnh in với các từ nổi bật ở những nơi được lựa chọn cẩn thận.

Hãy xem ví dụ này, biểu hiện lỗi làm tròn:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
43

Như bạn có thể thấy, hàm này không trả về giá trị dự kiến ​​của

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
85, nhưng bây giờ bạn đã biết nó vì số tiền này là một chút. Truy tìm trạng thái của các biến ở các bước khác nhau của thuật toán có thể cho bạn một gợi ý về vấn đề này.

Trong trường hợp này, vấn đề nằm ở cách các số điểm nổi được thể hiện trong bộ nhớ máy tính. Hãy nhớ rằng các con số được lưu trữ ở dạng nhị phân. Giá trị thập phân của

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
85 hóa ra có một biểu diễn nhị phân vô hạn, được làm tròn.floating point numbers are represented in computer memory. Remember that numbers are stored in binary form. Decimal value of
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
85 turns out to have an infinite binary representation, which gets rounded.

Để biết thêm thông tin về các số làm tròn trong Python, bạn có thể kiểm tra cách làm tròn số trong Python.

Phương pháp này đơn giản và trực quan và sẽ hoạt động trong hầu hết mọi ngôn ngữ lập trình ngoài kia. Chưa kể, nó là một bài tập tuyệt vời trong quá trình học tập.

Mặt khác, một khi bạn thành thạo các kỹ thuật nâng cao hơn, nó khó có thể quay lại, bởi vì chúng cho phép bạn tìm lỗi nhanh hơn nhiều. Truy tìm là một quá trình thủ công tốn nhiều công sức, có thể cho phép nhiều lỗi hơn nữa. Chu kỳ xây dựng và triển khai cần có thời gian. Sau đó, bạn cần nhớ loại bỏ một cách tỉ mỉ tất cả các cuộc gọi

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 bạn đã thực hiện mà không vô tình chạm vào những cuộc gọi chính hãng.

Bên cạnh đó, nó đòi hỏi bạn phải thực hiện các thay đổi trong mã, điều này luôn luôn có thể. Có thể bạn đang gỡ lỗi một ứng dụng đang chạy trong một máy chủ web từ xa hoặc muốn chẩn đoán vấn đề theo kiểu sau khi chết. Đôi khi bạn chỉ đơn giản là không có quyền truy cập vào đầu ra tiêu chuẩn.post-mortem fashion. Sometimes you simply don’t have access to the standard output.

Đó chính xác là nơi ghi nhật ký tỏa sáng.

Đăng nhập

Hãy để giả vờ trong một phút rằng bạn đang điều hành một trang web thương mại điện tử. Một ngày nọ, một khách hàng tức giận gọi điện thoại phàn nàn về một giao dịch thất bại và nói rằng anh ta đã mất tiền. Anh ta tuyên bố đã thử mua một vài mặt hàng, nhưng cuối cùng, có một số lỗi khó hiểu đã ngăn anh ta hoàn thành thứ tự đó. Tuy nhiên, khi anh ta kiểm tra tài khoản ngân hàng của mình, tiền đã biến mất.

Bạn xin lỗi chân thành và hoàn lại tiền, nhưng cũng không muốn điều này xảy ra một lần nữa trong tương lai. Làm thế nào để bạn gỡ lỗi điều đó? Nếu chỉ có bạn có một số dấu vết của những gì đã xảy ra, lý tưởng nhất là dưới dạng một danh sách thời gian của các sự kiện với bối cảnh của họ.

Bất cứ khi nào bạn thấy mình đang thực hiện gỡ lỗi in, hãy xem xét biến nó thành các tin nhắn nhật ký vĩnh viễn. Điều này có thể giúp trong các tình huống như thế này, khi bạn cần phân tích một vấn đề sau khi nó xảy ra, trong một môi trường mà bạn không có quyền truy cập.

Có các công cụ tinh vi để tập hợp và tìm kiếm nhật ký, nhưng ở cấp độ cơ bản nhất, bạn có thể nghĩ về nhật ký dưới dạng tệp văn bản. Mỗi dòng truyền tải thông tin chi tiết về một sự kiện trong hệ thống của bạn. Thông thường, nó đã thắng được chứa thông tin nhận dạng cá nhân, mặc dù, trong một số trường hợp, nó có thể được ủy quyền theo luật.

Ở đây, một sự cố của một bản ghi nhật ký điển hình:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
44

Như bạn có thể thấy, nó có một hình thức có cấu trúc. Ngoài một thông điệp mô tả, có một vài trường có thể tùy chỉnh, cung cấp bối cảnh của một sự kiện. Ở đây, bạn có ngày và thời gian chính xác, mức nhật ký, tên logger và tên luồng.

Các cấp độ nhật ký cho phép bạn lọc tin nhắn nhanh chóng để giảm tiếng ồn. Ví dụ, nếu bạn đang tìm kiếm một lỗi, bạn không muốn xem tất cả các cảnh báo hoặc tin nhắn gỡ lỗi. Nó tầm thường để vô hiệu hóa hoặc bật tin nhắn ở một số mức nhật ký nhất định thông qua cấu hình mà không cần chạm vào mã.

Với việc ghi nhật ký, bạn có thể giữ các thông báo gỡ lỗi của mình tách biệt với đầu ra tiêu chuẩn. Tất cả các thông báo nhật ký đi đến luồng lỗi tiêu chuẩn theo mặc định, có thể thuận tiện hiển thị với các màu khác nhau. Tuy nhiên, bạn có thể chuyển hướng tin nhắn nhật ký sang các tệp riêng biệt, ngay cả đối với các mô -đun riêng lẻ!

Khá phổ biến, việc ghi nhật ký bị cấu hình sai có thể dẫn đến việc hết dung lượng trên đĩa máy chủ. Để ngăn chặn điều đó, bạn có thể thiết lập vòng quay nhật ký, sẽ giữ các tệp nhật ký trong một thời lượng được chỉ định, chẳng hạn như một tuần hoặc khi chúng đạt kích thước nhất định. Tuy nhiên, nó luôn luôn là một thực hành tốt để lưu trữ các bản ghi cũ hơn. Một số quy định thực thi rằng dữ liệu khách hàng được lưu giữ trong năm năm!log rotation, which will keep the log files for a specified duration, such as one week, or once they hit a certain size. Nevertheless, it’s always a good practice to archive older logs. Some regulations enforce that customer data be kept for as long as five years!

So với các ngôn ngữ lập trình khác, việc đăng nhập vào Python đơn giản hơn, bởi vì mô -đun

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
84 được gói với thư viện tiêu chuẩn. Bạn chỉ cần nhập và định cấu hình nó chỉ bằng hai dòng mã:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
45

Bạn có thể gọi các chức năng được xác định ở cấp mô -đun, được nối với bộ ghi gốc, nhưng nhiều thông thường hơn là có được một bộ ghi chuyên dụng cho mỗi tệp nguồn của bạn:root logger, but more the common practice is to obtain a dedicated logger for each of your source files:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
46

Ưu điểm của việc sử dụng logger tùy chỉnh là kiểm soát hạt mịn hơn. Họ thường được đặt tên theo mô -đun mà chúng được xác định thông qua biến

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
89.

Một lý do cuối cùng để chuyển từ hàm

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 sang ghi nhật ký là an toàn của luồng. Trong phần sắp tới, bạn sẽ thấy rằng trước đây không chơi tốt với nhiều chủ đề thực thi.

Gỡ lỗi

Sự thật là không theo dõi cũng như ghi nhật ký có thể được coi là gỡ lỗi thực sự. Để thực hiện gỡ lỗi thực tế, bạn cần một công cụ gỡ lỗi, cho phép bạn thực hiện như sau:

  • Bước qua mã tương tác.
  • Đặt các điểm dừng, bao gồm các điểm dừng có điều kiện.
  • Các biến nội tâm trong bộ nhớ.
  • Đánh giá các biểu thức tùy chỉnh trong thời gian chạy.

Một trình gỡ lỗi thô thiển chạy trong thiết bị đầu cuối, không có tên là

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
91 cho Trình gỡ lỗi Python, được phân phối như một phần của thư viện tiêu chuẩn. Điều này làm cho nó luôn luôn có sẵn, vì vậy nó có thể là lựa chọn duy nhất của bạn để thực hiện gỡ lỗi từ xa. Có lẽ đó là một lý do tốt để làm quen với nó.
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
91
for “The Python Debugger,” is distributed as part of the standard library. This makes it always available, so it may be your only choice for performing remote debugging. Perhaps that’s a good reason to get familiar with it.

Tuy nhiên, nó không đi kèm với một giao diện đồ họa, vì vậy sử dụng

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
91 có thể hơi khó khăn. Nếu bạn có thể chỉnh sửa mã, bạn phải chạy nó như một mô -đun và vượt qua vị trí tập lệnh của bạn:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
47

Nếu không, bạn có thể thiết lập một điểm dừng trực tiếp trong mã, điều này sẽ tạm dừng việc thực thi tập lệnh của bạn và thả bạn vào trình gỡ lỗi. Cách cũ để làm điều này đòi hỏi hai bước:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
48

Điều này cho thấy một lời nhắc tương tác, có thể trông đáng sợ lúc đầu. Tuy nhiên, bạn vẫn có thể gõ Python bản địa tại thời điểm này để kiểm tra hoặc sửa đổi trạng thái của các biến cục bộ. Ngoài ra, còn có một số ít các lệnh dành riêng cho trình gỡ lỗi mà bạn muốn sử dụng để bước qua mã.

Vì Python 3.7, bạn cũng có thể gọi hàm

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
93 tích hợp, thực hiện điều tương tự, nhưng theo cách nhỏ gọn hơn và với một số chuông và còi bổ sung:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
49

Bạn có thể sẽ sử dụng trình gỡ lỗi trực quan được tích hợp với trình chỉnh sửa mã cho hầu hết các phần. Pycharm có một trình gỡ lỗi tuyệt vời, tự hào có hiệu suất cao, nhưng bạn sẽ tìm thấy rất nhiều IDE thay thế với các trình gỡ lỗi, cả được trả tiền và miễn phí.

Gỡ lỗi là một viên đạn bạc tục ngữ. Đôi khi ghi nhật ký hoặc truy tìm sẽ là một giải pháp tốt hơn. Ví dụ, các khiếm khuyết khó sinh sản, chẳng hạn như điều kiện chủng tộc, thường là kết quả của việc ghép thời gian. Khi bạn dừng lại ở điểm dừng, việc tạm dừng nhỏ đó trong việc thực hiện chương trình có thể che giấu vấn đề. Nó giống như nguyên tắc Heisenberg: bạn có thể đo lường và quan sát một lỗi cùng một lúc.

Những phương pháp này không phải là loại trừ lẫn nhau. Họ bổ sung cho nhau.

In an toàn chủ đề

Tôi đã chạm vào một thời gian ngắn về vấn đề an toàn chủ đề trước đây, đề xuất

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
84 qua hàm
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75. Nếu bạn vẫn đang đọc điều này, thì bạn phải thoải mái với khái niệm về chủ đề.

An toàn chủ đề có nghĩa là một đoạn mã có thể được chia sẻ một cách an toàn giữa nhiều luồng thực thi. Chiến lược đơn giản nhất để đảm bảo an toàn chủ đề là chỉ chia sẻ các đối tượng bất biến. Nếu các chủ đề có thể sửa đổi một trạng thái đối tượng, thì không có nguy cơ phá vỡ tính nhất quán của nó.immutable objects only. If threads can’t modify an object’s state, then there’s no risk of breaking its consistency.

Một phương pháp khác tận dụng bộ nhớ cục bộ, làm cho mỗi luồng nhận được bản sao của cùng một đối tượng. Bằng cách đó, các chủ đề khác có thể thấy những thay đổi được thực hiện trong chủ đề hiện tại.local memory, which makes each thread receive its own copy of the same object. That way, other threads can’t see the changes made to it in the current thread.

Nhưng điều đó không giải quyết được vấn đề, phải không? Bạn thường muốn các chủ đề của bạn hợp tác bằng cách có thể biến đổi một nguồn lực chung. Cách phổ biến nhất để đồng bộ hóa quyền truy cập đồng thời vào một tài nguyên như vậy là bằng cách khóa nó. Điều này cung cấp quyền truy cập ghi độc quyền vào một hoặc đôi khi một vài luồng tại một thời điểm.locking it. This gives exclusive write access to one or sometimes a few threads at a time.

Tuy nhiên, khóa là tốn kém và giảm thông lượng đồng thời, do đó, các phương tiện khác để kiểm soát truy cập đã được phát minh, chẳng hạn như các biến nguyên tử hoặc thuật toán so sánh và hoán đổi.atomic variables or the compare-and-swap algorithm.

In in không an toàn cho Python. Hàm

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 giữ một tham chiếu đến đầu ra tiêu chuẩn, là một biến toàn cầu được chia sẻ. Về lý thuyết, vì không có khóa, một công tắc ngữ cảnh có thể xảy ra trong cuộc gọi đến
lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
76, xen kẽ các bit văn bản từ nhiều cuộc gọi
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75.

Trong thực tế, tuy nhiên, điều đó không xảy ra. Cho dù bạn cố gắng thế nào, viết vào đầu ra tiêu chuẩn dường như là nguyên tử. Vấn đề duy nhất mà đôi khi bạn có thể quan sát là với các lần phá vỡ dòng lộn xộn:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
50

Để mô phỏng điều này, bạn có thể tăng khả năng chuyển đổi ngữ cảnh bằng cách thực hiện phương pháp

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
89 cơ bản đi ngủ trong một khoảng thời gian ngẫu nhiên. Làm sao? Bằng cách chế giễu nó, mà bạn đã biết từ một phần trước đó:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
51

Đầu tiên, bạn cần lưu trữ phương thức

r = reprlib.Repr[]
r.maxlist = 4       # max elements displayed for lists
r.maxstring = 10    # max characters displayed for strings

obj = [[1, 2, 3], list[range[10000]], 'looooooong string', 'a', 'b', 'c']

print[r.repr[obj]]
89 ban đầu trong một biến, mà bạn sẽ ủy thác cho sau này. Sau đó, bạn cung cấp triển khai giả mạo của bạn, sẽ mất đến một giây để thực hiện. Mỗi luồng sẽ thực hiện một vài cuộc gọi
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 với tên và một chữ cái: A, B và C.

Nếu bạn đọc phần chế giễu trước đây, thì bạn có thể đã có ý tưởng về lý do tại sao in các hành vi sai trái như vậy. Tuy nhiên, để làm cho nó rõ ràng, bạn có thể nắm bắt các giá trị được đưa vào hàm

[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
02 của bạn. Bạn sẽ nhận thấy rằng bạn nhận được một chuỗi hơi khác nhau mỗi lần:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
52

Mặc dù bản thân

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
76 là một hoạt động nguyên tử, một cuộc gọi duy nhất đến hàm
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 có thể mang lại nhiều hơn một lần ghi. Ví dụ, các lần ngắt dòng được viết tách biệt với phần còn lại của văn bản và việc chuyển đổi ngữ cảnh diễn ra giữa các lần viết đó.

Bạn có thể làm cho ký tự mới trở thành một phần không thể thiếu của thông điệp bằng cách xử lý nó theo cách thủ công:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
53

Điều này sẽ sửa chữa đầu ra:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
54

Tuy nhiên, lưu ý rằng chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 vẫn tiếp tục thực hiện một cuộc gọi riêng cho hậu tố trống, điều này chuyển sang hướng dẫn vô dụng
[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
06:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
55

Một phiên bản thực sự an toàn cho chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 có thể trông như thế này:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
56

Bạn có thể đặt chức năng đó vào một mô -đun và nhập nó ở nơi khác:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
57

Bây giờ, mặc dù thực hiện hai lần ghi cho mỗi yêu cầu

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75, chỉ có một luồng được phép tương tác với luồng, trong khi phần còn lại phải chờ:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
58

Tôi đã thêm nhận xét để cho biết cách khóa đang giới hạn quyền truy cập vào tài nguyên được chia sẻ.

Ngược lại, mô-đun

lst = [1, 2, 3]
lst.append[lst]  # oh my!

r = reprlib.Repr[]
r.maxlevel = 5   # max recursion depth

print[r.repr[lst]]
84 an toàn theo luồng theo thiết kế, được phản ánh bởi khả năng hiển thị tên luồng trong thông báo được định dạng:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
59

Đó là một lý do khác tại sao bạn có thể không muốn sử dụng chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 mọi lúc.

Các đối tác in Python

Đến bây giờ, bạn biết rất nhiều điều cần biết về

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75! Tuy nhiên, chủ đề này sẽ hoàn thành mà không nói về các đối tác của nó một chút. Trong khi
[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 là về đầu ra, có các chức năng và thư viện cho đầu vào.

Built-In

Python đi kèm với một chức năng tích hợp để chấp nhận đầu vào từ người dùng, được dự đoán là

[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
13. Nó chấp nhận dữ liệu từ luồng đầu vào tiêu chuẩn, thường là bàn phím:

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
60

Đó là một lý do khác tại sao bạn có thể không muốn sử dụng chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 mọi lúc.

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
61

Các đối tác in Python

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
62

Đó là một lý do khác tại sao bạn có thể không muốn sử dụng chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 mọi lúc.

Các đối tác in Python

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
63

Đó là một lý do khác tại sao bạn có thể không muốn sử dụng chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 mọi lúc.

>>>

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
64

Đó là một lý do khác tại sao bạn có thể không muốn sử dụng chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 mọi lúc.

Third-Party

Các đối tác in Python

  • Đến bây giờ, bạn biết rất nhiều điều cần biết về
    [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    75! Tuy nhiên, chủ đề này sẽ hoàn thành mà không nói về các đối tác của nó một chút. Trong khi
    [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    75 là về đầu ra, có các chức năng và thư viện cho đầu vào.
  • Python đi kèm với một chức năng tích hợp để chấp nhận đầu vào từ người dùng, được dự đoán là
    [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
    
    13. Nó chấp nhận dữ liệu từ luồng đầu vào tiêu chuẩn, thường là bàn phím:
  • Chức năng luôn trả về một chuỗi, vì vậy bạn có thể cần phải phân tích nó phù hợp:
  • Tham số nhắc nhở hoàn toàn tùy chọn, vì vậy sẽ không có gì hiển thị nếu bạn bỏ qua nó, nhưng chức năng vẫn sẽ hoạt động:
  • Tuy nhiên, việc ném vào một cuộc gọi hành động mô tả làm cho trải nghiệm người dùng tốt hơn rất nhiều.
  • Yêu cầu người dùng về mật khẩu với
    [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
    
    13 là một ý tưởng tồi vì nó sẽ hiển thị trong bản rõ khi họ gõ nó. Trong trường hợp này, bạn nên sử dụng chức năng
    [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
    
    15 thay thế, mặt nạ gõ các ký tự. Hàm này được xác định trong một mô -đun dưới cùng tên, cũng có sẵn trong thư viện tiêu chuẩn:
  • Mô -đun
    [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
    
    16 có một chức năng khác để lấy tên người dùng từ một biến môi trường:
  • Các chức năng tích hợp trong các chức năng tích hợp của Python để xử lý đầu vào tiêu chuẩn khá hạn chế. Đồng thời, có rất nhiều gói của bên thứ ba, cung cấp các công cụ tinh vi hơn nhiều.

Có các gói Python bên ngoài ngoài kia cho phép xây dựng các giao diện đồ họa phức tạp đặc biệt để thu thập dữ liệu từ người dùng. Một số tính năng của họ bao gồm:

  • [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
    
    17
  • [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
    
    18
  • [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
    
    19
  • [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
    
    20

Định dạng và kiểu dáng nâng cao

Tự động phân tích cú pháp, xác thực và vệ sinh dữ liệu người dùng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
65

Một phong cách khai báo xác định bố cục

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
66

Tương tác tự động hoàn thànhLeft arrow, for example, results in this instead of moving the cursor back:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
67

Bây giờ, bạn có thể bọc cùng một tập lệnh với lệnh

[1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [1, 2, 3, [...]]]]]]
21. Bạn không chỉ có các phím mũi tên hoạt động mà còn có thể tìm kiếm thông qua lịch sử liên tục của các lệnh tùy chỉnh, sử dụng tự động hoàn thành và chỉnh sửa dòng bằng các phím tắt:

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
68

Có phải là tuyệt vời không?

Sự kết luận

Bây giờ bạn được trang bị một cơ thể kiến ​​thức về chức năng

[[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
75 trong Python, cũng như nhiều chủ đề xung quanh. Bạn có một sự hiểu biết sâu sắc về nó là gì và cách thức hoạt động của nó, liên quan đến tất cả các yếu tố chính của nó. Nhiều ví dụ đã cho bạn cái nhìn sâu sắc về sự tiến hóa của nó từ Python 2.

Ngoài ra, bạn đã học được cách:

  • Tránh những sai lầm phổ biến với
    [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    75 trong Python
  • Đối phó với Newlines, mã hóa nhân vật và bộ đệm
  • Viết văn bản vào các tệp
  • Chế giễu chức năng
    [[1, 2, 3], [0, 1, 2, 3, 4, 5, ...]]
    
    75 trong các bài kiểm tra đơn vị
  • Xây dựng giao diện người dùng nâng cao trong thiết bị đầu cuối

Bây giờ bạn đã biết tất cả điều này, bạn có thể tạo các chương trình tương tác giao tiếp với người dùng hoặc tạo dữ liệu ở các định dạng tệp phổ biến. Bạn có thể nhanh chóng chẩn đoán các vấn đề trong mã của mình và bảo vệ chính mình khỏi chúng. Cuối cùng nhưng không kém phần quan trọng, bạn biết cách thực hiện trò chơi rắn cổ điển.

Nếu bạn vẫn còn khát nước để biết thêm thông tin, có câu hỏi hoặc đơn giản là muốn chia sẻ suy nghĩ của bạn, thì hãy thoải mái tiếp cận trong phần bình luận bên dưới.

Xem bây giờ hướng dẫn này có một khóa học video liên quan được tạo bởi nhóm Python thực sự. Xem nó cùng với hướng dẫn bằng văn bản để làm sâu sắc thêm sự hiểu biết của bạn: hàm python in []: vượt xa những điều cơ bản This tutorial has a related video course created by the Real Python team. Watch it together with the written tutorial to deepen your understanding: The Python print[] Function: Go Beyond the Basics

Làm cách nào để giới hạn các ký tự trong Python?

Sử dụng một chuỗi được định dạng theo nghĩa đen để định dạng một chuỗi và giới hạn độ dài của nó, ví dụ: result = f '{my_str: 5.5}'. Bạn có thể sử dụng các biểu thức trong các chuỗi F để giới hạn độ dài của chuỗi ở một số ký tự nhất định., e.g. result = f'{my_str:5.5}' . You can use expressions in f-strings to limit the string's length to a given number of characters.

Làm thế nào để bạn in ấn in trong Python?

Làm thế nào để xả đầu ra của in python ?..
Trong Python 3, cuộc gọi in [..., flush = true] [đối số tuôn ra không có sẵn trong hàm in của Python 2 và không có tương tự cho câu lệnh in] ..
Gọi File.flush [] trên tệp đầu ra [chúng ta có thể kết thúc chức năng in của Python 2 để thực hiện việc này], ví dụ: sys.stdout ..

Làm thế nào để bạn thực hiện một điểm dừng hoàn toàn trong Python?

Bạn có thể "thêm" [concatenate] ký tự khoảng thời gian vào cuối chuỗi.Ví dụ: "Harpreet đang học Python" + "!"# Mã này trả về "Harpreet đang học Python!""add" [concatenate] the period character to the end of the string. For example: "Harpreet is learning Python" + "!" # This code returns "Harpreet is learning Python!"

Làm thế nào để bạn gán đầu ra in cho một biến trong Python?

Để gán đầu ra của hàm in [] cho một biến: Xóa cuộc gọi cho hàm và gán đối số bạn đã chuyển để in [] cho biến.Hàm in [] chuyển đổi giá trị được cung cấp thành một chuỗi, in nó thành sys.Remove the call to the function and assign the argument you passed to print[] to the variable. The print[] function converts the provided value to a string, prints it to sys.

Bài Viết Liên Quan

Chủ Đề