gpt4 book ai didi

Python:用于元组的 Pandas DataFrame

转载 作者:太空宇宙 更新时间:2023-11-03 13:13:27 24 4
gpt4 key购买 nike

这是为元组创建 DataFrame 的正确方法吗? (假设元组是在代码片段中创建的)

import pandas as pd
import numpy as np
import random

row = ['a','b','c']
col = ['A','B','C','D']

# use numpy for creating a ZEROS matrix
st = np.zeros((len(row),len(col)))
df2 = pd.DataFrame(st, index=row, columns=col)

# CONVERT each cell to an OBJECT for inserting tuples
for c in col:
df2[c] = df2[c].astype(object)

print df2

for i in row:
for j in col:
df2.set_value(i, j, (i+j, np.round(random.uniform(0, 1), 4)))

print df2

如您所见,我首先在 numpy 中创建了一个 zeros(3,4),然后在 Pandas 中将每个单元格设为 OBJECT 类型,以便我可以插入元组。这是正确的做法还是有更好的解决方案来向矩阵添加/检索元组?

结果很好:

   A  B  C  D
a 0 0 0 0
b 0 0 0 0
c 0 0 0 0


A B C D
a (aA, 0.7134) (aB, 0.006) (aC, 0.1948) (aD, 0.2158)
b (bA, 0.2937) (bB, 0.8083) (bC, 0.3597) (bD, 0.324)
c (cA, 0.9534) (cB, 0.9666) (cC, 0.7489) (cD, 0.8599)

最佳答案

首先,回答你的字面问题:你可以从列表的列表中构造 DataFrame。列表列表中的值本身可以是元组:

import numpy as np
import pandas as pd
np.random.seed(2016)

row = ['a','b','c']
col = ['A','B','C','D']

data = [[(i+j, round(np.random.uniform(0, 1), 4)) for j in col] for i in row]
df = pd.DataFrame(data, index=row, columns=col)
print(df)

产量

              A             B             C             D
a (aA, 0.8967) (aB, 0.7302) (aC, 0.7833) (aD, 0.7417)
b (bA, 0.4621) (bB, 0.6426) (bC, 0.2249) (bD, 0.7085)
c (cA, 0.7471) (cB, 0.6251) (cC, 0.58) (cD, 0.2426)

话虽如此,但请注意,将元组存储在 DataFrame 中会使您陷入 Python 速度循环。要利用快速 Pandas/NumPy 例程,您需要使用原生 NumPy 数据类型,例如 np.float64(而相比之下,元组需要“object”数据类型)。

因此,也许更好的解决方案是使用两个单独的 DataFrame,一个用于字符串,一个用于数字:

import numpy as np
import pandas as pd
np.random.seed(2016)

row=['a','b','c']
col=['A','B','C','D']

prevstate = pd.DataFrame([[i+j for j in col] for i in row], index=row, columns=col)
prob = pd.DataFrame(np.random.uniform(0, 1, size=(len(row), len(col))).round(4),
index=row, columns=col)
print(prevstate)
# A B C D
# a aA aB aC aD
# b bA bB bC bD
# c cA cB cC cD

print(prob)
# A B C D
# a 0.8967 0.7302 0.7833 0.7417
# b 0.4621 0.6426 0.2249 0.7085
# c 0.7471 0.6251 0.5800 0.2426

要遍历列,找到概率最大的行并检索相应的 prevstate,您可以使用 .idxmax.loc :

for col in prob.columns:
idx = (prob[col].idxmax())
print('{}: {}'.format(prevstate.loc[idx, col], prob.loc[idx, col]))

产量

aA: 0.8967
aB: 0.7302
aC: 0.7833
aD: 0.7417

关于Python:用于元组的 Pandas DataFrame,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37092187/

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