我有一个 pandas.DataFrame
,我想将它转换为一个具有 MultiIndex
的 pandas.DataFrame
。
import numpy
import pandas
import itertools
xs = numpy.linspace(0, 10, 100)
ys = numpy.linspace(0, 0.1, 20)
zs = numpy.linspace(0, 5, 200)
def func(x, y, z):
return x * y / z
vals = list(itertools.product(xs, ys, zs))
result = [func(x, y, z) for x, y, z in vals]
# Original DataFrame.
df = pandas.DataFrame(vals, columns=['x', 'y', 'z'])
df = pandas.concat((pandas.DataFrame(result, columns=['result']), df), axis=1)
# I want to turn `df` into this `df2`.
index = pandas.MultiIndex.from_tuples(vals, names=['x', 'y', 'z'])
df2 = pandas.DataFrame(result, columns=['result'], index=index)
请注意,这个例子中我创建了我想要的和我拥有的内容。因此,在现实生活中,我将从df开始,并希望将其转换为df2(并且无法访问vals和result),我该如何做到这一点?
x
和y
列的第一个值之后,所有常见值都有空格。 - Murtaza Hajix,y
下面的空字符串是干什么用的?这只是为了显示。 - jezrael