对于如何定义python轴,以及它们是否引用DataFrame的行或列,我一直感到困惑。考虑下面的代码:
>>> df = pd.DataFrame([[1, 1, 1, 1], [2, 2, 2, 2], [3, 3, 3, 3]], columns=["col1", "col2", "col3", "col4"])
>>> df
col1 col2 col3 col4
0 1 1 1 1
1 2 2 2 2
2 3 3 3 3
因此,如果我们调用df.mean(axis=1)
,我们将在各行中获得均值:
>>> df.mean(axis=1)
0 1
1 2
2 3
但是,如果我们调用df.drop(name, axis=1)
,我们实际上会删除一列,而不是一行:
>>> df.drop("col4", axis=1)
col1 col2 col3
0 1 1 1
1 2 2 2
2 3 3 3
有人可以帮助我了解pandas / numpy / scipy中“轴”的含义吗?
附带说明,DataFrame.mean
可能定义错误。它在 DataFrame.mean
的文档中说axis=1
应该表示列的均值,而不是行的均值...
参考方案
记住它可能是最简单的,即0 = down和1 = across。
这表示:
axis=0
在每一列或行标签(索引)下应用方法。 axis=1
在每行或列标签上应用方法。 这是一张图片,显示每个轴均引用的DataFrame部分:
记住熊猫遵循NumPy对axis
的使用也很有用。用法在NumPy的glossary of terms中进行了解释:
为一维以上的数组定义了轴。二维数组具有两个对应的轴:第一个垂直向下在行上延伸(轴0),第二个垂直向下在行上延伸(列1)。 [我的重点]
因此,关于问题中的方法df.mean(axis=1)
,似乎已正确定义。它以水平方式跨列(即沿每一行)获取条目的平均值。另一方面,df.mean(axis=0)
将是跨行垂直向下作用的操作。
同样,df.drop(name, axis=1)
指的是对列标签的操作,因为它们直观地跨水平轴。指定axis=0
将使该方法作用于行。
我有一个Python脚本在某些深度学习模型上运行推理。有什么办法可以找出GPU资源的利用率水平?例如,使用着色器,float16乘法器等。我似乎在网上找不到太多有关这些GPU资源的文档。谢谢! 参考方案 您可以尝试在像Renderdoc这样的GPU分析器中运行pyxthon应用程序。它将分析您的跑步情况。您将能够获得有关已使用资源,已用缓冲区,不同渲染状态上…
Python:如何从字节中提取特定位? - python我有一条消息,显示为14 09 00 79 3d 00 23 27。我可以通过调用message[4]从此消息中提取每个字节,例如,这将给我3d。如何从该字节中提取单个8位?例如,如何将24-27位作为单个消息?只需28位? 参考方案 要回答问题的第二部分,您可以使用按位运算来获取特定的位值# getting your message as int i = …
重命名默认ID python - python我想连接两个dataFrames,但是两个数据具有不同的ID,所以结果是错误的这是我的代码data=pd.DataFrame(df.columns) data1=data.drop(axis=1,index=[0,1,2,3]).transpose() data1 这是dataframe1另一个数据框:y=sma_algo(df.loc['H+L&…
Python:图像处理可产生皱纹纸效果 - python也许很难描述我的问题。我正在寻找Python中的算法,以在带有某些文本的白色图像上创建皱纹纸效果。我的第一个尝试是在带有文字的图像上添加一些真实的皱纹纸图像(具有透明度)。看起来不错,但副作用是文本没有真正起皱。所以我正在寻找更好的解决方案,有什么想法吗?谢谢 参考方案 除了使用透明性之外,假设您有两张相同尺寸的图像,一张在皱纹纸上明亮,一张在白色背景上有深…
Python uuid4,如何限制唯一字符的长度 - python在Python中,我正在使用uuid4()方法创建唯一的字符集。但是我找不到将其限制为10或8个字符的方法。有什么办法吗?uuid4()ffc69c1b-9d87-4c19-8dac-c09ca857e3fc谢谢。 参考方案 尝试:x = uuid4() str(x)[:8] 输出:"ffc69c1b" Is there a way to…