Skip to content
This repository has been archived by the owner on Jun 14, 2023. It is now read-only.

Commit

Permalink
Merge pull request #32 from adelosa/bugfix/encoding-issues
Browse files Browse the repository at this point in the history
Setup and Install fixes
  • Loading branch information
adelosa authored Oct 2, 2016
2 parents e1ecb98 + 2263853 commit adf6823
Show file tree
Hide file tree
Showing 5 changed files with 49 additions and 13 deletions.
3 changes: 1 addition & 2 deletions MANIFEST.in
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@ recursive-exclude * *.py[co]

recursive-include docs *.rst conf.py Makefile make.bat

# package specific instructions
include mciutil/cli/mideu.yml
recursive-include *.yml
include versioneer.py
include mciutil/_version.py
37 changes: 30 additions & 7 deletions mciutil/cli/common.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
import sys
import logging
import csv
from pkg_resources import resource_filename

LOGGER = logging.getLogger(__name__)

Expand Down Expand Up @@ -86,12 +87,14 @@ def get_config_filename(config_filename):
user_home_dir = os.path.expanduser("~")

if os.path.isfile(current_dir + "/" + config_filename):
return current_dir + "/" + config_filename
config_filename = current_dir + "/" + config_filename
elif os.path.isfile(user_home_dir + "/." + config_filename):
return user_home_dir + "/." + config_filename
config_filename = user_home_dir + "/." + config_filename
else:
module_dir = os.path.dirname(os.path.abspath(__file__))
return module_dir + "/" + config_filename
module_dir = resource_filename("mciutil", "cli")
config_filename = module_dir + "/" + config_filename
LOGGER.info("Using {0} config file".format(config_filename))
return config_filename


def add_to_csv(data_list, field_list, output_filename):
Expand All @@ -103,20 +106,40 @@ def add_to_csv(data_list, field_list, output_filename):
:param output_filename: filename for output CSV file
:return: None
"""
try:
instance_type = unicode
file_mode = "wb"
except NameError:
instance_type = str
file_mode = "w"

filtered_data_list = filter_data_list(data_list, field_list)

with open(output_filename, "w") as output_file:
with open(output_filename, file_mode) as output_file:
writer = csv.DictWriter(output_file,
fieldnames=field_list,
extrasaction="ignore",
lineterminator="\n")

# python 2.6 does not support writeheader() so skip
if sys.version_info[0] == 2 and sys.version_info[1] == 6:
pass
else:
writer.writeheader()

writer.writerows(filtered_data_list)
for item in filtered_data_list:
if file_mode == "w":
row = dict(
(k, v.decode('latin1') if not isinstance(v, instance_type) else v)
for k, v in item.items()
)
else:
row = dict(
(k, v.encode('utf-8') if isinstance(v, instance_type) else v)
for k, v in item.items()
)
writer.writerow(row)

LOGGER.info("%s records written", len(data_list))


Expand Down Expand Up @@ -145,7 +168,7 @@ def filter_dictionary(dictionary, field_list):
return_dictionary = {}
for item in dictionary:
if item in field_list:
return_dictionary[item] = dictionary[item].decode()
return_dictionary[item] = dictionary[item]

return return_dictionary

Expand Down
1 change: 0 additions & 1 deletion setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -5,5 +5,4 @@ universal = 1
VCS = git
style = pep440
versionfile_source = mciutil/_version.py
versionfile_build = mciutil/_version.py
tag_prefix =
5 changes: 3 additions & 2 deletions setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,9 +32,10 @@
packages=[
'mciutil', 'mciutil.cli'
],
package_dir={'mciutil':
'mciutil'},
include_package_data=True,
package_data={
'mciutil.cli': ['*.yml']
},
install_requires=requirements,
entry_points={
'console_scripts': [
Expand Down
16 changes: 15 additions & 1 deletion tests/test_mideu.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
# -*- coding: utf-8 -*-

from __future__ import absolute_import
import os.path
import sys
Expand Down Expand Up @@ -143,7 +145,19 @@ class FilteredDictionaryTest(TestCase):
def test_filter_dict(self):
dict = {"a": b("123"), "b": b("456"), "c": b("789")}
field_list = ["a", "c"]
expected_dict = {"a": "123", "c": "789"}
expected_dict = {"a": b("123"), "c": b("789")}
actual_dict = filter_dictionary(dict, field_list)
self.assertEqual(len(actual_dict), 2)
self.assertEqual(actual_dict, expected_dict)

def test_filter_dict_with_latin1(self):
dict = {
"a": b("123\xc9"),
"b": b("456\xc9"),
"c": b("789\xc9")
}
field_list = ["a", "c"]
expected_dict = {"a": b("123\xc9"), "c": b("789\xc9")}
actual_dict = filter_dictionary(dict, field_list)
self.assertEqual(len(actual_dict), 2)
self.assertEqual(actual_dict, expected_dict)
Expand Down

0 comments on commit adf6823

Please sign in to comment.