Skip to content

Commit 0d69a9b

Browse files
committed
Add more notes on regular expressions
1 parent 4719e72 commit 0d69a9b

File tree

2 files changed

+171
-2
lines changed

2 files changed

+171
-2
lines changed

.gitignore

Lines changed: 138 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,2 +1,138 @@
1-
*/.venv/*
2-
*/__pycache__
1+
# Byte-compiled / optimized / DLL files
2+
__pycache__/
3+
*.py[cod]
4+
*$py.class
5+
6+
# C extensions
7+
*.so
8+
9+
# Distribution / packaging
10+
.Python
11+
build/
12+
develop-eggs/
13+
dist/
14+
downloads/
15+
eggs/
16+
.eggs/
17+
lib/
18+
lib64/
19+
parts/
20+
sdist/
21+
var/
22+
wheels/
23+
share/python-wheels/
24+
*.egg-info/
25+
.installed.cfg
26+
*.egg
27+
MANIFEST
28+
29+
# PyInstaller
30+
# Usually these files are written by a python script from a template
31+
# before PyInstaller builds the exe, so as to inject date/other infos into it.
32+
*.manifest
33+
*.spec
34+
35+
# Installer logs
36+
pip-log.txt
37+
pip-delete-this-directory.txt
38+
39+
# Unit test / coverage reports
40+
htmlcov/
41+
.tox/
42+
.nox/
43+
.coverage
44+
.coverage.*
45+
.cache
46+
nosetests.xml
47+
coverage.xml
48+
*.cover
49+
*.py,cover
50+
.hypothesis/
51+
.pytest_cache/
52+
cover/
53+
54+
# Translations
55+
*.mo
56+
*.pot
57+
58+
# Django stuff:
59+
*.log
60+
local_settings.py
61+
db.sqlite3
62+
db.sqlite3-journal
63+
64+
# Flask stuff:
65+
instance/
66+
.webassets-cache
67+
68+
# Scrapy stuff:
69+
.scrapy
70+
71+
# Sphinx documentation
72+
docs/_build/
73+
74+
# PyBuilder
75+
.pybuilder/
76+
target/
77+
78+
# Jupyter Notebook
79+
.ipynb_checkpoints
80+
81+
# IPython
82+
profile_default/
83+
ipython_config.py
84+
85+
# pyenv
86+
# For a library or package, you might want to ignore these files since the code is
87+
# intended to run in multiple environments; otherwise, check them in:
88+
# .python-version
89+
90+
# pipenv
91+
# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control.
92+
# However, in case of collaboration, if having platform-specific dependencies or dependencies
93+
# having no cross-platform support, pipenv may install dependencies that don't work, or not
94+
# install all needed dependencies.
95+
#Pipfile.lock
96+
97+
# PEP 582; used by e.g. github.com/David-OConnor/pyflow
98+
__pypackages__/
99+
100+
# Celery stuff
101+
celerybeat-schedule
102+
celerybeat.pid
103+
104+
# SageMath parsed files
105+
*.sage.py
106+
107+
# Environments
108+
.env
109+
.venv
110+
env/
111+
venv/
112+
ENV/
113+
env.bak/
114+
venv.bak/
115+
116+
# Spyder project settings
117+
.spyderproject
118+
.spyproject
119+
120+
# Rope project settings
121+
.ropeproject
122+
123+
# mkdocs documentation
124+
/site
125+
126+
# mypy
127+
.mypy_cache/
128+
.dmypy.json
129+
dmypy.json
130+
131+
# Pyre type checker
132+
.pyre/
133+
134+
# pytype static type analyzer
135+
.pytype/
136+
137+
# Cython debug symbols
138+
cython_debug/

README.md

Lines changed: 33 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2861,3 +2861,36 @@ Potential use cases include:
28612861
- advanced find/replace in text
28622862
- formatting text/output
28632863
- syntax highlighting
2864+
2865+
| Character | Matches |
2866+
| --------- | --------------------------------- |
2867+
| \d | digit 0-9 |
2868+
| \w | letter, digit or underscore |
2869+
| \s | whitespace character |
2870+
| \D | not a digit |
2871+
| \W | not a letter, digit or underscore |
2872+
| \S | not a whitespace character |
2873+
| . | any character except line break |
2874+
2875+
| Quantifier | Matches |
2876+
| ---------- | ------------------------------ |
2877+
| + | one or more |
2878+
| {3} | exactly x times. {3} - 3 times |
2879+
| {3,5} | Three to five times |
2880+
| {4,} | Four or more times |
2881+
| \* | zero or more times |
2882+
| ? | once or none (optional |
2883+
2884+
You can create a group of acceptable values using `[]`, for example `[a-zA-Z0-9]`.
2885+
2886+
Inside `[]` `^` means not, rather than starts with. So `[^@$]` means any character that is not @ or $.
2887+
2888+
| Character | Sets boundary |
2889+
| --------- | ----------------------- |
2890+
| ^ | start of string or line |
2891+
| $ | end of string or line |
2892+
| \b | word boundary |
2893+
2894+
`|` works as logical or. For example `\(\d{3}\)|\d{3}` matches three digits with or without parens.
2895+
2896+
`()` groups characters. `(\(\d{3}\)|\d{3}) \d{3} \d{4}`

0 commit comments

Comments
 (0)