Bộ python chứa tất cả

Giải pháp khái niệm hóa cho bất kỳ chuỗi nào (không chỉ là một chuỗi) và bất kỳ tập hợp nào (bất kỳ đối tượng nào trong đó có thể kiểm tra thành viên với toán tử)

[c in str for c in set]
0, không chỉ là một trong các ký tự).
def containsAny(str, set):
    """ Check whether sequence str contains ANY of the items in set. """
    return 1 in [c in str for c in set]

def containsAll(str, set):
    """ Check whether sequence str contains ALL of the items in set. """
    return 0 not in [c in str for c in set]

Thảo luận

Mặc dù các chuỗi phương thức

[c in str for c in set]
1 và
[c in str for c in set]
2 có thể kiểm tra các lần xuất hiện của chuỗi con, không có chức năng nào được tạo sẵn để kiểm tra sự xuất hiện trong chuỗi của một tập hợp các ký tự

Trong khi làm việc với một điều kiện để kiểm tra xem một chuỗi có chứa các ký tự đặc biệt được sử dụng trong hàm thư viện tiêu chuẩn

[c in str for c in set]
3 hay không, tôi đã đưa ra mã trên (với sự trợ giúp từ kênh OpenProjects IRC
[c in str for c in set]
4). Được viết theo cách này, nó thực sự tương thích với suy nghĩ của con người, mặc dù bạn không thể đưa ra mã đó bằng trực giác. Thông thường đó là trường hợp với sự hiểu biết về danh sách

Mã sau đây tạo danh sách các giá trị ____ 15/________ 16, một cho mỗi mục trong tập hợp

[c in str for c in set]

Sau đó, kiểm tra mã này xem có ít nhất một giá trị thực trong danh sách đó không

1 in [c in str for c in set]

Tương tự, điều này kiểm tra xem không có giá trị giả nào có trong danh sách

________số 8

Các ví dụ sử dụng được sử dụng tốt nhất dưới dạng bài kiểm tra đơn vị được gắn vào tệp nguồn

[c in str for c in set]
7 của mô-đun này, với thành ngữ thông thường để đảm bảo rằng các thử nghiệm thực thi nếu mô-đun chạy dưới dạng lệnh chính.
def containsAny(str, set):
    """ Check whether sequence str contains ANY of the items in set. """
    return 1 in [c in str for c in set]

def containsAll(str, set):
    """ Check whether sequence str contains ALL of the items in set. """
    return 0 not in [c in str for c in set]
0

Tất nhiên, trong khi các thành ngữ trước đó gọn gàng, có những lựa chọn thay thế (luôn luôn ở đó?). Dưới đây là những người ở cơ bản nhất và làm điều đó, theo một nghĩa nào đó, những người thay thế Pythonic nhất

def containsAny(str, set):
    """ Check whether sequence str contains ANY of the items in set. """
    return 1 in [c in str for c in set]

def containsAll(str, set):
    """ Check whether sequence str contains ALL of the items in set. """
    return 0 not in [c in str for c in set]
1

Dưới đây là một số lựa chọn thay thế vòng quay tối thiểu chắc chắn (lợi nhuận sớm nhất có thể). Đây là những điều thú vị nhất và do đó, theo một nghĩa nào đó, mạnh mẽ nhất

def containsAny(str, set):
    """ Check whether sequence str contains ANY of the items in set. """
    return 1 in [c in str for c in set]

def containsAll(str, set):
    """ Check whether sequence str contains ALL of the items in set. """
    return 0 not in [c in str for c in set]
2

Dưới đây là một số biến có thể tăng hơn của các loại sau dựa trên một phương pháp đặc biệt chỉ cung cấp cho các đối tượng duy nhất trong Python 2. 2 trở lên

def containsAny(str, set):
    """ Check whether sequence str contains ANY of the items in set. """
    return 1 in [c in str for c in set]

def containsAll(str, set):
    """ Check whether sequence str contains ALL of the items in set. """
    return 0 not in [c in str for c in set]
3

Và đây là một biến thể khó khăn dựa vào chức năng cũng có sẵn trong 2. 0

def containsAny(str, set):
    """ Check whether sequence str contains ANY of the items in set. """
    return 1 in [c in str for c in set]

def containsAll(str, set):
    """ Check whether sequence str contains ALL of the items in set. """
    return 0 not in [c in str for c in set]
4

May mắn thay, cách tiếp cận khá khó khăn này thiếu một biến thể rõ ràng ngay lập tức áp dụng để thực hiện

[c in str for c in set]
8. Tuy nhiên, một sơ đồ khó khăn cuối cùng, dựa trên khả năng xóa tất cả các ký tự trong một bộ, áp dụng cho cả hai chức năng.
def containsAny(str, set):
    """ Check whether sequence str contains ANY of the items in set. """
    return 1 in [c in str for c in set]

def containsAll(str, set):
    """ Check whether sequence str contains ALL of the items in set. """
    return 0 not in [c in str for c in set]
6

Thủ thuật này ít nhất có một số độ sâu, nó dựa vào

1 in [c in str for c in set]
0 is the following section of
1 in [c in str for c in set]
1 was created to from the character not in
1 in [c in str for c in set]
2. If the string con that has the same length with
1 in [c in str for c in set]
1, then don't have anycharts are delete by
1 in [c in str for c in set]
4, do that, does not have character of
1 in [c in str for c in set]
1 is in
1 in [c in str for c in set]
2. Ngược lại, nếu chuỗi con đó có độ dài 0, tất cả các ký tự đã bị xóa, vì vậy tất cả các ký tự của
1 in [c in str for c in set]
1 đều ở trong
1 in [c in str for c in set]
2. Phương pháp
1 in [c in str for c in set]
9 của các chuỗi đối tượng tiếp tục xuất hiện một cách tự nhiên khi người ta muốn coi các chuỗi là bộ ký tự, một phần vì nó rất nhanh và một phần vì nó rất tiện dụng và linh hoạt. View Formula 3. 8 for a other application application

Một quan sát cuối cùng là những cách khác nhau để tiếp cận nhiệm vụ có mức độ tổng quát rất khác nhau. Ở một thái cực, cách tiếp cận sớm nhất, chỉ dựa vào