Skip to content
Projeler
Gruplar
Parçacıklar
Yardım
Yükleniyor...
Oturum aç / Kaydol
Gezinmeyi değiştir
C
cpython
Proje
Proje
Ayrıntılar
Etkinlik
Cycle Analytics
Depo (repository)
Depo (repository)
Dosyalar
Kayıtlar (commit)
Dallar (branch)
Etiketler
Katkıda bulunanlar
Grafik
Karşılaştır
Grafikler
Konular (issue)
0
Konular (issue)
0
Liste
Pano
Etiketler
Kilometre Taşları
Birleştirme (merge) Talepleri
0
Birleştirme (merge) Talepleri
0
CI / CD
CI / CD
İş akışları (pipeline)
İşler
Zamanlamalar
Grafikler
Paketler
Paketler
Wiki
Wiki
Parçacıklar
Parçacıklar
Üyeler
Üyeler
Collapse sidebar
Close sidebar
Etkinlik
Grafik
Grafikler
Yeni bir konu (issue) oluştur
İşler
Kayıtlar (commit)
Konu (issue) Panoları
Kenar çubuğunu aç
Batuhan Osman TASKAYA
cpython
Commits
1f268285
Kaydet (Commit)
1f268285
authored
Tem 28, 2009
tarafından
Mark Dickinson
Dosyalara gözat
Seçenekler
Dosyalara Gözat
İndir
Eposta Yamaları
Sade Fark
Issue #6561: '\d' in a regular expression should match only Unicode
character category [Nd], not [No].
üst
6bd13fbb
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
32 additions
and
6 deletions
+32
-6
re.rst
Doc/library/re.rst
+6
-5
test_re.py
Lib/test/test_re.py
+21
-0
NEWS
Misc/NEWS
+4
-0
_sre.c
Modules/_sre.c
+1
-1
No files found.
Doc/library/re.rst
Dosyayı görüntüle @
1f268285
...
@@ -338,11 +338,12 @@ the second character. For example, ``\$`` matches the character ``'$'``.
...
@@ -338,11 +338,12 @@ the second character. For example, ``\$`` matches the character ``'$'``.
``\d``
``\d``
For Unicode (str) patterns:
For Unicode (str) patterns:
Matches any Unicode digit (which includes ``[0-9]``, and also many
Matches any Unicode decimal digit (that is, any character in
other digit characters). If the :const:`ASCII` flag is used only
Unicode character category [Nd]). This includes ``[0-9]``, and
``[0-9]`` is matched (but the flag affects the entire regular
also many other digit characters. If the :const:`ASCII` flag is
expression, so in such cases using an explicit ``[0-9]`` may be a
used only ``[0-9]`` is matched (but the flag affects the entire
better choice).
regular expression, so in such cases using an explicit ``[0-9]``
may be a better choice).
For 8-bit (bytes) patterns:
For 8-bit (bytes) patterns:
Matches any decimal digit; this is equivalent to ``[0-9]``.
Matches any decimal digit; this is equivalent to ``[0-9]``.
...
...
Lib/test/test_re.py
Dosyayı görüntüle @
1f268285
...
@@ -605,6 +605,27 @@ class ReTests(unittest.TestCase):
...
@@ -605,6 +605,27 @@ class ReTests(unittest.TestCase):
self
.
assertEqual
(
next
(
iter
)
.
span
(),
(
4
,
4
))
self
.
assertEqual
(
next
(
iter
)
.
span
(),
(
4
,
4
))
self
.
assertRaises
(
StopIteration
,
next
,
iter
)
self
.
assertRaises
(
StopIteration
,
next
,
iter
)
def
test_bug_6561
(
self
):
# '\d' should match characters in Unicode category 'Nd'
# (Number, Decimal Digit), but not those in 'Nl' (Number,
# Letter) or 'No' (Number, Other).
decimal_digits
=
[
'
\u0037
'
,
# '\N{DIGIT SEVEN}', category 'Nd'
'
\u0e58
'
,
# '\N{THAI DIGIT SIX}', category 'Nd'
'
\uff10
'
,
# '\N{FULLWIDTH DIGIT ZERO}', category 'Nd'
]
for
x
in
decimal_digits
:
self
.
assertEqual
(
re
.
match
(
'^
\
d$'
,
x
)
.
group
(
0
),
x
)
not_decimal_digits
=
[
'
\u2165
'
,
# '\N{ROMAN NUMERAL SIX}', category 'Nl'
'
\u3039
'
,
# '\N{HANGZHOU NUMERAL TWENTY}', category 'Nl'
'
\u2082
'
,
# '\N{SUBSCRIPT TWO}', category 'No'
'
\u32b4
'
,
# '\N{CIRCLED NUMBER THIRTY NINE}', category 'No'
]
for
x
in
not_decimal_digits
:
self
.
assertIsNone
(
re
.
match
(
'^
\
d$'
,
x
))
def
test_empty_array
(
self
):
def
test_empty_array
(
self
):
# SF buf 1647541
# SF buf 1647541
import
array
import
array
...
...
Misc/NEWS
Dosyayı görüntüle @
1f268285
...
@@ -108,6 +108,10 @@ Library
...
@@ -108,6 +108,10 @@ Library
Extension Modules
Extension Modules
-----------------
-----------------
- Issue #6561: '\d' in a regex now matches only characters with
Unicode category 'Nd' (Number, Decimal Digit). Previously it also
matched characters with category 'No'.
- Issue #4509: Array objects are no longer modified after an operation
- Issue #4509: Array objects are no longer modified after an operation
failing due to the resize restriction in-place when the object has exported
failing due to the resize restriction in-place when the object has exported
buffers.
buffers.
...
...
Modules/_sre.c
Dosyayı görüntüle @
1f268285
...
@@ -168,7 +168,7 @@ static unsigned int sre_lower_locale(unsigned int ch)
...
@@ -168,7 +168,7 @@ static unsigned int sre_lower_locale(unsigned int ch)
#if defined(HAVE_UNICODE)
#if defined(HAVE_UNICODE)
#define SRE_UNI_IS_DIGIT(ch) Py_UNICODE_ISD
IGIT
((Py_UNICODE)(ch))
#define SRE_UNI_IS_DIGIT(ch) Py_UNICODE_ISD
ECIMAL
((Py_UNICODE)(ch))
#define SRE_UNI_IS_SPACE(ch) Py_UNICODE_ISSPACE((Py_UNICODE)(ch))
#define SRE_UNI_IS_SPACE(ch) Py_UNICODE_ISSPACE((Py_UNICODE)(ch))
#define SRE_UNI_IS_LINEBREAK(ch) Py_UNICODE_ISLINEBREAK((Py_UNICODE)(ch))
#define SRE_UNI_IS_LINEBREAK(ch) Py_UNICODE_ISLINEBREAK((Py_UNICODE)(ch))
#define SRE_UNI_IS_ALNUM(ch) Py_UNICODE_ISALNUM((Py_UNICODE)(ch))
#define SRE_UNI_IS_ALNUM(ch) Py_UNICODE_ISALNUM((Py_UNICODE)(ch))
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment