mirror of
https://github.com/ilri/csv-metadata-quality.git
synced 2024-11-21 21:35:02 +01:00
Refactor as package with subpackages
This makes it cleaner for introducing checks, fixes, tests, docs, and tests in the future. Currently can be run like this: python -m csv_metadata_quality CSV input and output paths are still hard coded. See: https://dev.to/codemouse92/dead-simple-python-project-structure-and-imports-38c6
This commit is contained in:
parent
ef5b8f7244
commit
232d28e13e
0
csv_metadata_quality/__init__.py
Normal file
0
csv_metadata_quality/__init__.py
Normal file
4
csv_metadata_quality/__main__.py
Normal file
4
csv_metadata_quality/__main__.py
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
from csv_metadata_quality import app
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
app.run()
|
17
csv_metadata_quality/app.py
Normal file
17
csv_metadata_quality/app.py
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
import csv_metadata_quality.fix as fix
|
||||||
|
import pandas as pd
|
||||||
|
|
||||||
|
def run():
|
||||||
|
# Read all fields as strings so dates don't get converted from 1998 to 1998.0
|
||||||
|
#df = pd.read_csv('/home/aorth/Downloads/2019-07-26-Bioversity-Migration.csv', dtype=str)
|
||||||
|
#df = pd.read_csv('/tmp/quality.csv', dtype=str)
|
||||||
|
df = pd.read_csv('/tmp/omg.csv', dtype=str)
|
||||||
|
|
||||||
|
# Fix whitespace in all columns
|
||||||
|
for column in df.columns.values.tolist():
|
||||||
|
print(f'DEBUG: {column}')
|
||||||
|
|
||||||
|
df[column] = df[column].apply(fix.whitespace)
|
||||||
|
|
||||||
|
# Write
|
||||||
|
df.to_csv('/tmp/omg.fixed.csv', index=False)
|
@ -1,14 +1,16 @@
|
|||||||
#!/usr/bin/env python3
|
|
||||||
|
|
||||||
import pandas as pd
|
import pandas as pd
|
||||||
|
import re
|
||||||
|
|
||||||
def fix_whitespace(field):
|
def alan():
|
||||||
|
print('Alan')
|
||||||
|
|
||||||
|
|
||||||
|
def whitespace(field):
|
||||||
"""Fix whitespace issues.
|
"""Fix whitespace issues.
|
||||||
|
|
||||||
Return string with leading, trailing, and consecutive whitespace trimmed.
|
Return string with leading, trailing, and consecutive whitespace trimmed.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
import re
|
|
||||||
|
|
||||||
# Skip fields with missing values
|
# Skip fields with missing values
|
||||||
if pd.isna(field):
|
if pd.isna(field):
|
||||||
@ -38,17 +40,3 @@ def fix_whitespace(field):
|
|||||||
|
|
||||||
return new_field
|
return new_field
|
||||||
|
|
||||||
|
|
||||||
# Read all fields as strings so dates don't get converted from 1998 to 1998.0
|
|
||||||
#df = pd.read_csv('/home/aorth/Downloads/2019-07-26-Bioversity-Migration.csv', dtype=str)
|
|
||||||
#df = pd.read_csv('/tmp/quality.csv', dtype=str)
|
|
||||||
df = pd.read_csv('/tmp/omg.csv', dtype=str)
|
|
||||||
|
|
||||||
# Fix whitespace in all columns
|
|
||||||
for column in df.columns.values.tolist():
|
|
||||||
print(f'DEBUG: {column}')
|
|
||||||
|
|
||||||
df[column] = df[column].apply(fix_whitespace)
|
|
||||||
|
|
||||||
# Write
|
|
||||||
df.to_csv('/tmp/omg.fixed.csv', index=False)
|
|
Loading…
Reference in New Issue
Block a user