Unverified Commit d2b1b194 authored by BaiJiangJie's avatar BaiJiangJie Committed by GitHub

Merge pull request #2765 from jumpserver/dev

Dev
parents 0a1a260a 49632241
......@@ -2,6 +2,7 @@
#
import json
import chardet
import unicodecsv
from rest_framework.parsers import BaseParser
......@@ -73,7 +74,6 @@ class JMSCSVParser(BaseParser):
def parse(self, stream, media_type=None, parser_context=None):
parser_context = parser_context or {}
encoding = parser_context.get('encoding', 'utf-8')
try:
serializer = parser_context["view"].get_serializer()
except Exception as e:
......@@ -82,6 +82,8 @@ class JMSCSVParser(BaseParser):
try:
stream_data = stream.read()
detect_result = chardet.detect(stream_data)
encoding = detect_result.get("encoding", "utf-8")
binary = self._universal_newlines(stream_data)
rows = self._gen_rows(binary, charset=encoding)
......@@ -97,5 +99,5 @@ class JMSCSVParser(BaseParser):
data.append(row_data)
return data
except Exception as e:
logger.debug(e, exc_info=True)
logger.error(e, exc_info=True)
raise ParseError('CSV parse error!')
......@@ -53,7 +53,6 @@ class JMSCSVRender(BaseRenderer):
def render(self, data, media_type=None, renderer_context=None):
renderer_context = renderer_context or {}
encoding = renderer_context.get('encoding', 'utf-8')
request = renderer_context['request']
template = request.query_params.get('template', 'export')
view = renderer_context['view']
......@@ -74,7 +73,7 @@ class JMSCSVRender(BaseRenderer):
table = self._gen_table(data, header, labels)
csv_buffer = BytesIO()
csv_writer = unicodecsv.writer(csv_buffer, encoding=encoding)
csv_writer = unicodecsv.writer(csv_buffer, encoding='utf-8-sig')
for row in table:
csv_writer.writerow(row)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment