python-stdnum branch master updated. 1.16-12-g4516748
[
Date Prev][
Date Next]
[
Thread Prev][
Thread Next]
python-stdnum branch master updated. 1.16-12-g4516748
- From: Commits of the python-stdnum project <python-stdnum-commits [at] lists.arthurdejong.org>
- To: python-stdnum-commits [at] lists.arthurdejong.org
- Reply-to: python-stdnum-users [at] lists.arthurdejong.org, python-stdnum-commits [at] lists.arthurdejong.org
- Subject: python-stdnum branch master updated. 1.16-12-g4516748
- Date: Sun, 25 Jul 2021 16:41:47 +0200 (CEST)
This is an automated email from the git hooks/post-receive script. It was
generated because a ref change was pushed to the repository containing
the project "python-stdnum".
The branch, master has been updated
via 45167482aa50efa62595be7d1895de8144b49cfd (commit)
from 4c51860388bd11fdd80102d683b928487adc511d (commit)
Those revisions listed above that are new to this repository have
not appeared on any other notification email; so we list those
revisions in full, below.
- Log -----------------------------------------------------------------
https://arthurdejong.org/git/python-stdnum/commit/?id=45167482aa50efa62595be7d1895de8144b49cfd
commit 45167482aa50efa62595be7d1895de8144b49cfd
Author: David Vaz <davidmgvaz@gmail.com>
Date: Wed Jun 9 12:38:39 2021 +0100
Add CC (Número de Cartão de Cidadão, Portuguese Identity number)
Closes https://github.com/arthurdejong/python-stdnum/pull/265
diff --git a/stdnum/pt/cc.py b/stdnum/pt/cc.py
new file mode 100644
index 0000000..baac0df
--- /dev/null
+++ b/stdnum/pt/cc.py
@@ -0,0 +1,92 @@
+# cc.py - functions for handling Portuguese Identity numbers
+# coding: utf-8
+#
+# Copyright (C) 2021 David Vaz
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+# 02110-1301 USA
+
+"""CC (Número de Cartão de Cidadão, Portuguese Identity number).
+
+The Portuguese Identity Number is alphanumeric and consists of the numeric
+Número de Identificação Civil, a two-letter version and a check digit.
+
+More information:
+
+* https://pt.wikipedia.org/wiki/Cartão_de_cidadão
+*
https://www.autenticacao.gov.pt/documents/20126/115760/Validação+de+Número+de+Documento+do+Cartão+de+Cidadão.pdf
+
+>>> validate('00000000 0 ZZ4')
+'000000000ZZ4'
+>>> validate('00000000 A ZZ4') # invalid format
+Traceback (most recent call last):
+ ...
+InvalidFormat: ...
+>>> validate('00000000 0 ZZ3') # invalid check digits
+Traceback (most recent call last):
+ ...
+InvalidChecksum: ...
+>>> format('000000000ZZ4')
+'00000000 0 ZZ4'
+"""
+
+import re
+
+from stdnum.exceptions import *
+from stdnum.util import clean
+
+
+_cc_re = re.compile(r'^\d*[A-Z0-9]{2}\d$')
+
+
+def compact(number):
+ """Convert the number to the minimal representation. This strips the
+ number of any valid separators and removes surrounding whitespace."""
+ number = clean(number, ' ').upper().strip()
+ return number
+
+
+def calc_check_digit(number):
+ """Calculate the check digit for the number."""
+ alphabet = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'
+ cutoff = lambda x: x - 9 if x > 9 else x
+ s = sum(
+ cutoff(alphabet.index(n) * 2) if i % 2 == 0 else alphabet.index(n)
+ for i, n in enumerate(number[::-1]))
+ return str((10 - s) % 10)
+
+
+def validate(number):
+ """Check if the number is a valid cartao de cidadao number."""
+ number = compact(number)
+ if not _cc_re.match(number):
+ raise InvalidFormat()
+ if calc_check_digit(number[:-1]) != number[-1]:
+ raise InvalidChecksum()
+ return number
+
+
+def is_valid(number):
+ """Check if the number is a valid cartao de cidadao number."""
+ try:
+ return bool(validate(number))
+ except ValidationError:
+ return False
+
+
+def format(number):
+ """Reformat the number to the standard presentation format."""
+ number = compact(number)
+ return ' '.join([number[:-4], number[-4], number[-3:]])
diff --git a/tests/test_pt_cc.doctest b/tests/test_pt_cc.doctest
new file mode 100644
index 0000000..bb2811a
--- /dev/null
+++ b/tests/test_pt_cc.doctest
@@ -0,0 +1,38 @@
+test_pt_cc.doctest - more detailed doctests for stdnum.pt.cc module
+
+Copyright (C) 2021 Arthur de Jong
+
+This library is free software; you can redistribute it and/or
+modify it under the terms of the GNU Lesser General Public
+License as published by the Free Software Foundation; either
+version 2.1 of the License, or (at your option) any later version.
+
+This library is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+Lesser General Public License for more details.
+
+You should have received a copy of the GNU Lesser General Public
+License along with this library; if not, write to the Free Software
+Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+02110-1301 USA
+
+
+This file contains more detailed doctests for the stdnum.pt.cc module. It
+tries to test more corner cases and detailed functionality that is not really
+useful as module documentation.
+
+>>> from stdnum.pt import cc
+
+
+These have been found online and should all be valid numbers.
+
+>>> numbers = '''
+...
+... 04521224 4 ZZ 7
+... 054546796ZY7
+... 101490801ZY0
+...
+... '''
+>>> [x for x in numbers.splitlines() if x and not cc.is_valid(x)]
+[]
-----------------------------------------------------------------------
Summary of changes:
stdnum/{imo.py => pt/cc.py} | 65 +++++++++++++----------
tests/{test_au_tfn.doctest => test_pt_cc.doctest} | 24 ++++-----
2 files changed, 46 insertions(+), 43 deletions(-)
copy stdnum/{imo.py => pt/cc.py} (51%)
copy tests/{test_au_tfn.doctest => test_pt_cc.doctest} (62%)
hooks/post-receive
--
python-stdnum
- python-stdnum branch master updated. 1.16-12-g4516748,
Commits of the python-stdnum project