Làm cách nào để kiểm tra xem một ký tự có được lặp lại trong chuỗi python không?
Thật dễ dàng trong Python để tìm ký tự lặp lại trong một chuỗi đã cho. Có nhiều cách để làm điều đó như sử dụng bảng chữ cái, vòng lặp for hoặc bộ sưu tập Show Chương trình Python để tìm ký tự lặp lại trong một chuỗi đã cho Ví dụMã ví dụ đơn giản Cách cơ bản quét chuỗi 26 lần
đầu ra Một cách khác là chỉ đi qua chuỗi một lầnKhoảng trắng cũng sẽ được tính trong phương thức này, vì vậy hãy áp dụng điều kiện if để xóa khoảng trắng trong số đếm
Sử dụng bộ sưu tập Cần nhập mô-đun bộ sưu tập
Hãy bình luận nếu bạn có bất kỳ nghi ngờ và đề xuất nào về chương trình Python char này
Rohit Bằng cấp về Khoa học Máy tính và Kỹ sư. Nhà phát triển ứng dụng và có kinh nghiệm về nhiều ngôn ngữ lập trình. Đam mê công nghệ & thích học hỏi kỹ thuật Giải pháp khái quát hóa cho bất kỳ chuỗi nào (không chỉ một chuỗi) và bất kỳ tập hợp nào (bất kỳ đối tượng nào có thể kiểm tra tư cách thành viên bằng toán tử [c in str for c in set]0, không chỉ 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] Mặc dù các phương thức chuỗi [c in str for c in set]1 và [c in str for c in set]2 có thể kiểm tra sự xuất hiện của chuỗi con, nhưng không có chức năng làm sẵn nào để kiểm tra sự xuất hiện trong một chuỗi gồm 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 chuẩn [c in str for c in set]3 hay không, tôi đã nghĩ ra đoạn mã trên (với sự trợ giúp từ kênh IRC của OpenProjects [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 có thể không nghĩ ra mã như vậy bằng trực giác. Đó thường là trường hợp với việc hiểu danh sách Đoạn mã sau tạo một danh sách các giá trị [c in str for c in set]5/ [c in str for c in set]6, một giá trị cho mỗi mục trong tập hợp [c in str for c in set] Sau đó, mã này kiểm tra xem có ít nhất một giá trị thực trong danh sách đó không 2Tương tự, điều này kiểm tra xem không có giá trị sai nào trong danh sách 3Các ví dụ sử dụng được truyền tốt nhất dưới dạng các bài kiểm tra đơn vị để được thêm 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 bài kiểm tra thực thi nếu mô-đun chạy dưới dạng tập lệnh chính 5Tất nhiên, trong khi các thành ngữ trước rất gọn gàng, vẫn có những lựa chọn thay thế (không phải lúc nào cũng vậy sao?). Dưới đây là những lựa chọn thay thế cơ bản nhất — và do đó, theo một nghĩa nào đó, là những lựa chọn thay thế Pythonic nhất 6Dưới đây là một số lựa chọn thay thế đảm bảo vòng lặp tối thiểu (trả lại sớm nhất có thể). Đây là những điều ngắn gọn nhất và do đó, theo một nghĩa nào đó, mạnh mẽ nhất 7Dưới đây là một số biến thể thậm chí còn mỏng hơn của biến thể thứ hai dựa trên một phương thức đặc biệt mà các đối tượng chuỗi chỉ cung cấp trong Python 2. 2 trở lên 8Và đây là một biến thể phức tạp dựa trên chức năng cũng có sẵn trong 2. 0 9May mắn thay, cách tiếp cận khá phức tạp này thiếu một biến thể rõ ràng ngay lập tức có thể áp dụng để triển khai [c in str for c in set]8. Tuy nhiên, một lược đồ phức tạp cuối cùng, dựa trên khả năng xóa tất cả các ký tự trong một tập hợp của [c in str for c in set]9, sẽ áp dụng cho cả hai chức năng 2Thủ thuật này ít nhất cũng có chiều sâu—nó dựa vào việc 20 là dãy con của 21 được tạo thành từ các ký tự không có trong 22. Nếu dãy con đó có cùng độ dài với 21, không có ký tự nào bị xóa bởi 24, vì vậy không có ký tự nào của 21 nằm trong 22. Ngược lại, nếu dãy con đó có độ dài bằng 0 thì tất cả các ký tự đã bị loại bỏ, do đó tất cả các ký tự của 21 nằm trong 22. Phương thức 29 của các đối tượng chuỗi 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à tập hợp các 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. Xem Công thức 3. 8 cho một ứng dụng tương tự khácMột quan sát cuối cùng là những cách tiếp cận nhiệm vụ khác nhau này 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 [c in str for c in set]0 (để lặp trên 22 và để trở thành thành viên của 21) là cách chung nhất; . Ở một thái cực khác, cách tiếp cận cuối cùng, dựa vào phương thức 29, chỉ hoạt động khi cả 22 và 21 đều là chuỗi hoặc chức năng của các đối tượng chuỗi gần giống nhaucông thức 3. số 8; |