From c99547aa9663076266965bff05cc99472f382c01 Mon Sep 17 00:00:00 2001 From: Bryan Newbold Date: Sat, 30 Jun 2018 14:48:11 -0700 Subject: fix issn importer booleans --- python/fatcat/issn_importer.py | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) (limited to 'python') diff --git a/python/fatcat/issn_importer.py b/python/fatcat/issn_importer.py index 69db8e66..eb45a640 100644 --- a/python/fatcat/issn_importer.py +++ b/python/fatcat/issn_importer.py @@ -15,6 +15,17 @@ def or_none(s): return None return s +def truthy(s): + if s is None: + return None + s = s.lower() + if s in ('true', 't', 'yes', 'y', '1'): + return True + elif s in ('false', 'f', 'no', 'n', '0'): + return False + else: + return None + class FatcatIssnImporter(FatcatImporter): def parse_issn_row(self, row): @@ -27,14 +38,14 @@ class FatcatIssnImporter(FatcatImporter): if title is None or issnl is None: return extra = dict( - in_doaj=bool(row['in_doaj']), - in_road=bool(row['in_road']), + in_doaj=truthy(row['in_doaj']), + in_road=truthy(row['in_road']), language=or_none(row['lang']), url=or_none(row['url']), ISSNp=or_none(row['ISSN-print']), ISSNe=or_none(row['ISSN-electronic']), - is_oa=bool(row['is_oa']), - is_kept=bool(row['is_kept']), + is_oa=truthy(row['is_oa']), + is_kept=truthy(row['is_kept']), ) ce = fatcat_client.ContainerEntity( issnl=issnl, -- cgit v1.2.3