python - 使用仅对角线数据的表中的值创建一行

标签 python pandas if-statement null append

我在 Pandas 中有下表-

>>>index1   index2   index3   index4   index5   index6   index7
0   sig      null    null     null     null     null     null
1   null      sig     null     null     null     null     null
2   null      null    sig      null     null     null     null
3   null      null    null     sig      null     null     null
4   null      null    null     null     no sig   null     null
5   null      null    null     null     null     no sig   null
6   null      null    null     null     null     null     sig
我想摆脱减少空值并将数据放在一行中,如下所示:
>>>index1   index2   index3   index4   index5   index6   index7
0   sig      sig     sig      sig      no sig   no sig   sig
重要的是,我通过 if 语句获得了第一个包含空数据的表;我已经计算了每个索引的统计检验,并根据 p 值,我使用 append 给每个索引值 sig 或 no sig:
for i in indices:
    stat, p = friedmanchisquare(df[1][i],df[2][i],df[3][i],df[4][i],df[5][i])
    #print(i,p)
    if p<0.05:
        friedman=friedman.append({i:'sig'},ignore_index=True)
    else:
        friedman=friedman.append({i:'no sig'},ignore_index=True)
所以我相信 append 创建了具有许多空值的大表。
我的最终目标:在 of 循环阶段获得单行表(例如,使用除 append 之外的其他内容?)或在获得单行之后“修复”大表

最佳答案

你可以试试np.diagonal返回 diagonal元素:

d = pd.DataFrame([np.diagonal(df)], columns=df.columns)
  index1 index2 index3 index4  index5  index6 index7
0    sig    sig    sig    sig  no sig  no sig    sig

关于python - 使用仅对角线数据的表中的值创建一行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63805747/

相关文章:

java - if 语句中的 NullPointerException

Excel VBA(非常慢)如果满足条件则将整行移动到底部

c++ - 带有模板类的 SWIG SHARED_PTR 宏

python - 创建可共享模块的正确方法(包导入)

python - 根据两列的值删除数据框 pandas 中的重复项

python - 从数据帧中的字符串中提取浮点值

java错误不是报表-电费单

python - Neo4j cypher 查询结果到 Pandas DataFrame

python - 为什么所有这些 un​​icode 命令在 Python 中都能正确工作?无论我做什么,它们都正确地打印出我的字符

python - 使用 Django 模板标签 'slice' 切片 pandas 数据框?