【发布时间】:2020-03-08 16:04:16
【问题描述】:
但是,我想从三元组中删除最后一个值并使用样式对其进行编码。 IE。:
但是,我不知道如何结合这两个步骤。 对于 pandas 25.x pandas retain styling when reformatting cells - without reparsing string to numbers 演示了一个可能的答案,但是,我需要让它适用于 pandas 1.0.1。
df = pd.DataFrame({'foo': {'first': ['-0.89495', '0.48868', '0.06978'],
'second': ['0.50249', '0.07999', '0.00000'],
'3rd': ['-0.75436', '0.20239', '0.00031']},
'bar': {'first': ['-0.49294',
'0.61195',
'0.42228'],
'second': ['0.35000', '0.10999', '0.00191'],
'3rd': ['-0.62354', '0.28775', '0.03250']}})
def highlight_significant(x, sign_level_1, sign_level_2):
if x is np.nan:
return ''
else:
if isinstance(x, list):
p_value = float(x[2])
if float(x[0]) > 0:
if p_value < sign_level_2:
return 'font-weight: bold;background-color: lightgreen'
elif p_value < sign_level_1:
color = 'lightgreen'
return 'background-color: %s' % color
else:
return ''
else:
if p_value < sign_level_2:
return 'font-weight: bold;background-color: yellow'
elif p_value < sign_level_1:
color = 'yellow'
return 'background-color: %s' % color
else:
return ''
else:
return ''
display(df)
display(df.style.applymap(highlight_significant, sign_level_1=0.05, sign_level_2=0.01))
def format_regression_results(r):
if len(r)> 1:
coefficient = r[0]
std_err = r[1]
p_value = round(float(r[2]), rounding_digits)
result = f'{round(float(coefficient), rounding_digits)} ({round(float(std_err), rounding_digits)})'
return result
else:
return '-'
df.foo = df.foo.apply(format_regression_results)
df.bar = df.bar.apply(format_regression_results)
df
编辑
确实:
def make_float(x):
return [float(x[0]), float(x[1]), float(x[2])]
df.foo = df.foo.apply(make_float)
df.bar = df.bar.apply(make_float)
重新格式化:
styles = lambda x: df.applymap(lambda x: highlight_significant(x, sign_level_1=0.05, sign_level_2=0.01))
dx = df.applymap(lambda x: f'{x[0]}({round(float(x[1]), 2)})')
display(dx)
有效。但是,样式仍然丢失。
【问题讨论】:
-
您的第一个数据框包含浮点数列表,而您的第二个数据框包含字符串列表,您的示例也是如此。可能您要做的第一件事就是将所有内容都转换为浮点数。
-
当然 - 但仍然没有应用样式。