From 4d4b48cc6e6d596591def698f59eff56c9a6ae38 Mon Sep 17 00:00:00 2001 From: davhj <31554275+DavidHJong@users.noreply.github.com> Date: Tue, 14 Nov 2023 08:02:37 +0800 Subject: [PATCH] Add handling for duplicate column names in DBF files --- dbfread/dbf.py | 12 +++++++++++- dbfread/version.py | 2 +- setup.py | 6 +++--- 3 files changed, 15 insertions(+), 5 deletions(-) diff --git a/dbfread/dbf.py b/dbfread/dbf.py index 65d45ac..00e9c18 100644 --- a/dbfread/dbf.py +++ b/dbfread/dbf.py @@ -224,6 +224,9 @@ def _decode_text(self, data): return data.decode(self.encoding, errors=self.char_decode_errors) def _read_field_headers(self, infile): + field_names = set() + field_counter = {} + while True: sep = infile.read(1) if sep in (b'\r', b'\n', b''): @@ -245,8 +248,15 @@ def _read_field_headers(self, infile): if self.lowernames: field.name = field.name.lower() - self.field_names.append(field.name) + # Check for duplicate field names and append a suffix + original_name = field.name + if field.name in field_names: + field_counter[original_name] = field_counter.get(original_name, 0) + 1 + field.name = f"{original_name}_{field_counter[original_name]}" + else: + field_names.add(field.name) + self.field_names.append(field.name) self.fields.append(field) def _open_memofile(self): diff --git a/dbfread/version.py b/dbfread/version.py index 8c4261a..bc46d07 100644 --- a/dbfread/version.py +++ b/dbfread/version.py @@ -15,5 +15,5 @@ def _make_version_info(version): return VersionInfo(major, minor, micro, releaselevel, 0) -version = '2.0.7' +version = '2.0.8' version_info = _make_version_info(version) diff --git a/setup.py b/setup.py index c5c1ca7..f3232eb 100755 --- a/setup.py +++ b/setup.py @@ -34,9 +34,9 @@ include_package_data=True, zip_safe=True, install_requires=[], - python_requires='>=2.7.*, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*, !=3.5.*', + python_requires='>=2.7, !=3.0, !=3.1, !=3.2, !=3.3, !=3.4, !=3.5', license='MIT', - classifiers=( + classifiers=[ 'Development Status :: 5 - Production/Stable', 'Intended Audience :: Developers', 'Natural Language :: English', @@ -52,5 +52,5 @@ 'Programming Language :: Python :: 3.10', 'Programming Language :: Python :: Implementation :: CPython', 'Programming Language :: Python :: Implementation :: PyPy', - ), + ], )