Pandas to_excel 会损坏 '='

问题描述 投票:0回答:2

我在将等号从

DataFrame
写入 Excel 文件时遇到问题:
我读取了一个 Excel 文件(我想在将来修改它),并将
DataFrame
写回 Excel 文件。 Dataframe 包含等号 (=),在输出 excel 文件中显示为 0。

我已经检查过等号的数据类型,它是 unicode: u'=' 。 我附上了我使用的代码,以及一些额外的调试输出(我希望有帮助)。

fname = os.path.join(baseDIR, PARAMETERS_FILE)
base_params = read_excel (fname, PARAMETERS_SHEET)
base_params.override = False
>>> base_params.operator
0      rev
1      rev
2      rev
3      rev
4      rev
5      rev
6      rev
7      rev
8      rev
9       >=
10       =
11      <=
12      <=
13      <=
14      <=
15     NaN
16       =
17       =
18       =
19     NaN
Name: operator, dtype: object
out_file = os.path.join(onDIR, PARAMETERS_FILE)
writer = ExcelWriter(out_file)
base_params.to_excel(writer, PARAMETERS_SHEET, index=False, encoding='utf-8')
writer.save()    
>>> pd.show_versions()

INSTALLED VERSIONS
------------------
commit: None
python: 2.7.10.final.0
python-bits: 64
OS: Windows
OS-release: 7
machine: AMD64
processor: Intel64 Family 6 Model 58 Stepping 9, GenuineIntel
byteorder: little
LC_ALL: None
LANG: de_AT

pandas: 0.16.2
nose: 1.3.7
Cython: 0.22.1
numpy: 1.9.2
scipy: 0.15.1
statsmodels: None
IPython: 3.2.0
sphinx: 1.3.1
patsy: 0.3.0
dateutil: 2.4.2
pytz: 2015.4
bottleneck: None
tables: 3.2.0
numexpr: 2.4.3
matplotlib: 1.4.3
openpyxl: None
xlrd: 0.9.3
xlwt: None
xlsxwriter: 0.7.3
lxml: 3.4.4
bs4: 4.3.2
html5lib: None
httplib2: None
apiclient: None
sqlalchemy: 1.0.5
pymysql: None
psycopg2: None

在我得到的输出 Excel 文件中; '=' 被替换为 0。

python excel pandas
2个回答
1
投票

要让 Excel 按字面意思显示单元格中的内容,您需要在内容前面加上单引号:

'
,这将阻止它尝试将内容作为公式进行计算。

所以,不要写

"="
,而是写
"'="

或者,当然,将单元格格式更改为

Text
。默认值为
General
,它将尝试评估所有内容。


0
投票

用 '= 替换 = 对我来说不起作用,' 字符在 Excel 中仍然可见。这就是我最终所做的:

df["operator"].str.replace("=", "\u200B=")

\u200B 在 Excel 中不可见

© www.soinside.com 2019 - 2024. All rights reserved.