PYTHON REGEX
CÁC CHỦ ĐỀ
BÀI MỚI NHẤT
MỚI CẬP NHẬT

Thông báo: Download 4 khóa học Python từ cơ bản đến nâng cao tại đây.

Các lượng từ trong Regex của Python

Trong quá trình xử lý và kiểm tra dữ liệu văn bản, biểu thức chính quy (regex) là một công cụ vô cùng mạnh mẽ và linh hoạt. Một trong những tính năng quan trọng của biểu thức chính quy là các lượng từ, cho phép bạn xác định số lần lặp lại của một ký tự hoặc một tập hợp ký tự cụ thể. Trong bài viết này, mình sẽ tìm hiểu về các lượng từ trong biểu thức chính quy của Python, bao gồm cách sử dụng chúng để khớp với các mẫu chuỗi một cách chính xác và hiệu quả.

test php

banquyen png
Bài viết này được đăng tại freetuts.net, không được copy dưới mọi hình thức.

Giới thiệu về các lượng từ trong Regex của Python

Trong biểu thức chính quy, lượng từ khớp với các ký tự hoặc tập hợp ký tự trước đó một số lần nhất định. Bảng sau đây cho thấy tất cả các lượng từ và ý nghĩa của chúng:

Lượng từ Tên gọi Ý nghĩa
* Dấu hoa thị Khớp với phần tử trước đó không hoặc nhiều lần.
+ Dấu cộng Khớp với phần tử trước đó một hoặc nhiều lần.
? Dấu chấm hỏi Khớp với phần tử trước đó không hoặc một lần.
{ n } Ngoặc nhọn Khớp với phần tử trước đó đúng n lần.
{ n ,} Ngoặc nhọn Khớp với phần tử trước đó ít nhất n lần.
{ n , m } Ngoặc nhọn Khớp với phần tử trước đó từ n đến m lần.

Khớp không hoặc nhiều lần (*)

Lượng từ (*) khớp với phần tử trước đó không hoặc nhiều lần. Ví dụ, chương trình sau sử dụng lượng từ * để khớp với bất kỳ chuỗi nào kết thúc bằng "Python":

import re

s = """CPython, IronPython, và JPython 
       là các triển khai chính của Python"""

matches = re.finditer(r'\w*Python', s)

for match in matches:
    print(match.group())

Trong ví dụ này:

Bài viết này được đăng tại [free tuts .net]

  • \w khớp với bất kỳ ký tự chữ cái nào.
  • \w* khớp với không hoặc nhiều ký tự chữ cái.
  • Do đó, \w*Python khớp với bất kỳ chuỗi nào không hoặc nhiều ký tự theo sau bởi "Python".

Kết quả, biểu thức \w*Python sẽ khớp với CPython, IronPython, JPython, và Python trong chuỗi:

CPython
IronPython
JPython
Python

Khớp một hoặc nhiều lần (+)

Lượng từ + khớp với phần tử trước đó một hoặc nhiều lần. Ví dụ, \d+ khớp với một hoặc nhiều chữ số.

Chương trình sau sử dụng lượng từ + để khớp với một hoặc nhiều chữ số trong một chuỗi:

import re

s = "Python 3.10 được phát hành vào năm 2021"

matches = re.finditer(r'\d+', s)

for match in matches:
    print(match.group())

Kết quả:

3
10
2021

Khớp không hoặc một lần (?)

Lượng từ ? khớp với phần tử trước đó không hoặc một lần.

Ví dụ sau sử dụng lượng từ ? để khớp với cả hai chuỗi "color" và "colour":

import re

s = "Bạn thích màu color / colour nào?"

matches = re.finditer(r'colou?r', s)

for match in matches:
    print(match.group())

Kết quả:

color
colour

Khớp đúng n lần: {n}

Lượng từ {n} khớp với phần tử trước đó đúng n lần, trong đó n là số nguyên dương hoặc bằng 0.

Ví dụ, chương trình sau sử dụng lượng từ {n} để khớp với một chuỗi thời gian theo định dạng hh:mm:

import re

s = "Đó là 11:05 AM"

matches = re.finditer(r'\d{2}:\d{2}', s)

for match in matches:
    print(match.group())

Kết quả:

11:05

Khớp ít nhất n lần: {n,}

Lượng từ {n,} khớp với phần tử trước đó ít nhất n lần, trong đó n là số nguyên dương hoặc bằng 0.

Ví dụ, chương trình sau sử dụng lượng từ {n,} để khớp với các chuỗi ngày tháng theo định dạng m-d-yyyy hoặc mm-dd-yyyy:

import re

s = "5-5-2021 hoặc 05-05-2021 hoặc 5/5/2021"

matches = re.finditer(r'\d{1,}-\d{1,}-\d{4}', s)

for match in matches:
    print(match.group())

Kết quả:

5-5-2021
05-05-2021

Khớp từ n đến m lần: {n,m}

Lượng từ {n,m} khớp với phần tử trước đó ít nhất n lần, nhưng không nhiều hơn m lần, trong đó n và m là các số nguyên dương hoặc bằng 0.

import re

s = "5-5-2021 hoặc 05-05-2021 hoặc 5/5/2021"

matches = re.finditer(r'\d{1,2}-\d{1,2}-\d{4}', s)

for match in matches:
    print(match.group())

Kết quả:

5-5-2021
05-05-2021

Trong ví dụ này, biểu thức \d{1,2} khớp với một hoặc hai chữ số. Do đó, biểu thức \d{1,2}-\d{1,2}-\d{4} khớp với một chuỗi ngày tháng theo định dạng d-m-yyyy hoặc dd-mm-yyyy.

Kết bài

Các lượng từ trong biểu thức chính quy Python cho phép bạn kiểm soát số lần lặp lại của các ký tự hoặc tập hợp ký tự, từ đó tạo ra các mẫu khớp phức tạp và linh hoạt hơn. Bằng cách hiểu và áp dụng đúng các lượng từ như *, +, ?, {n}, {n,}, và {n,m}, bạn có thể xây dựng các biểu thức chính quy mạnh mẽ để xử lý và kiểm tra dữ liệu văn bản một cách hiệu quả. Với sự hiểu biết về các lượng từ này, bạn sẽ có thể viết các biểu thức chính quy chính xác hơn, giúp giải quyết nhiều bài toán thực tế trong lập trình và phân tích dữ liệu.

Cùng chuyên mục:

Cách thêm Progress Bar trong Python với chỉ một dòng Code

Cách thêm Progress Bar trong Python với chỉ một dòng Code

Toán tử Walrus Operator- Tính năng mới trong Python 3.8

Toán tử Walrus Operator- Tính năng mới trong Python 3.8

Cách nạp dữ liệu Machine Learning từ File trong Python

Cách nạp dữ liệu Machine Learning từ File trong Python

Hướng dẫn sử dụng Google Sheets API với Python

Hướng dẫn sử dụng Google Sheets API với Python

Xây dựng  web Python tự động hóa Twitter | Flask, Heroku, Twitter API & Google Sheets API

Xây dựng web Python tự động hóa Twitter | Flask, Heroku, Twitter API & Google Sheets API

Xây dựng Web Machine Learning đẹp mắt với Streamlit và Scikit-learn trong Python

Xây dựng Web Machine Learning đẹp mắt với Streamlit và Scikit-learn trong Python

Hướng dẫn tạo Chatbot đơn giản bằng PyTorch

Hướng dẫn tạo Chatbot đơn giản bằng PyTorch

11 mẹo và thủ thuật để viết Code Python hiệu quả hơn

11 mẹo và thủ thuật để viết Code Python hiệu quả hơn

Hướng dẫn làm ứng dụng TODO với Flask dành cho người mới bắt đầu trong Python

Hướng dẫn làm ứng dụng TODO với Flask dành cho người mới bắt đầu trong Python

Hướng dẫn viết Snake Game bằng Python

Hướng dẫn viết Snake Game bằng Python

Cách sử dụng chế độ interactive trong Python

Cách sử dụng chế độ interactive trong Python

Cách sử dụng Python Debugger với hàm breakpoint()

Cách sử dụng Python Debugger với hàm breakpoint()

Xây dựng ứng dụng Web Style Transfer với PyTorch và Streamlit

Xây dựng ứng dụng Web Style Transfer với PyTorch và Streamlit

Cách cài đặt Jupyter Notebook trong môi trường Conda và thêm Kernel

Cách cài đặt Jupyter Notebook trong môi trường Conda và thêm Kernel

Hướng dẫn xây dựng ứng dụng dự đoán giá cổ phiếu bằng Python

Hướng dẫn xây dựng ứng dụng dự đoán giá cổ phiếu bằng Python

Hướng dẫn tạo ứng dụng AI hội thoại với NVIDIA Jarvis trong Python

Hướng dẫn tạo ứng dụng AI hội thoại với NVIDIA Jarvis trong Python

Hỗ trợ Async trong Django 3.1

Hỗ trợ Async trong Django 3.1

8 mẹo tái cấu trúc Python giúp mã sạch hơn và Pythonic

8 mẹo tái cấu trúc Python giúp mã sạch hơn và Pythonic

Ý nghĩa của if __name__ ==

Ý nghĩa của if __name__ == "__main__" trong Python

Cách xóa phần tử trong danh sách Python

Cách xóa phần tử trong danh sách Python

Top