gpt4 book ai didi

python - 使用 Pandas 返回排序行的索引值?

转载 作者:太空宇宙 更新时间:2023-11-04 07:43:07 25 4
gpt4 key购买 nike

我最近才发现 Pandas 的力量。 (感谢 Wes McKinney!)我有一个包含以下信息的 csv:

RUN_START_DATE,PUSHUP_START_DATE,SITUP_START_DATE,PULLUP_START_DATE
2013-01-24,2013-01-02,2013-01-30,2013-02-03
2013-01-30,2013-01-21,2013-01-13,2013-01-06
2013-01-29,2013-01-28,2013-01-01,2013-01-29
2013-02-16,2013-02-12,2013-01-04,2013-02-11
2013-01-06,2013-02-07,2013-02-25,2013-02-12
2013-01-26,2013-01-28,2013-02-12,2013-01-10
2013-01-26,2013-02-10,2013-01-12,2013-01-30
2013-01-03,2013-01-24,2013-01-19,2013-01-02
2013-01-22,2013-01-13,2013-02-03,2013-02-05
2013-02-06,2013-01-16,2013-02-07,2013-01-11

通常,我不会在这个过程中使用 pandas。我使用 csv 库生成列表。使用日期时间库转换它们。然后我遍历每一行并运行类似下面的内容来获取每一行的排序索引:

'"' + ','.join(map(str, sorted(range(len(dates)), key=lambda k: dates[k]))) + '"'

然后它为每一行返回如下内容:

Out[40]: '"1,0,2,3"'

然后我将它添加到每一行的末尾作为我的 csv 中的一个新字段。

我可以将 csv 读入 pandas 并将项目转换为日期 dtype。我只是不确定如何使用 pandas 获取排序的索引值,然后将它们展平成一个字符串并将它们放入一个列中?非常感谢任何帮助!

最佳答案

您可以使用 numpy.argsort() 获取排序索引:

from StringIO import StringIO
import numpy as np
import pandas as pd

txt = """RUN_START_DATE,PUSHUP_START_DATE,SITUP_START_DATE,PULLUP_START_DATE
2013-01-24,2013-01-02,2013-01-30,2013-02-03
2013-01-30,2013-01-21,2013-01-13,2013-01-06
2013-01-29,2013-01-28,2013-01-01,2013-01-29
2013-02-16,2013-02-12,2013-01-04,2013-02-11
2013-01-06,2013-02-07,2013-02-25,2013-02-12
2013-01-26,2013-01-28,2013-02-12,2013-01-10
2013-01-26,2013-02-10,2013-01-12,2013-01-30
2013-01-03,2013-01-24,2013-01-19,2013-01-02
2013-01-22,2013-01-13,2013-02-03,2013-02-05
2013-02-06,2013-01-16,2013-02-07,2013-01-11"""
df = pd.read_csv(StringIO(txt))
idx = np.argsort(df, axis=1)
buf = StringIO()
idx.to_csv(buf, index=False, header=False)
print buf.getvalue()

输出:

1,0,2,3
3,2,1,0
2,1,0,3
2,3,1,0
0,1,3,2
3,0,1,2
2,0,3,1
3,0,2,1
1,0,2,3
3,1,0,2

关于python - 使用 Pandas 返回排序行的索引值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15137877/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com