- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有两个数据框。
dataframe1 =
Product sample element2 element3
W100 XX1 40 10
W100 XX2 30 40
W100 XZ1 30 20
W100 XZ3 10 20
W100 AB2 20 30
W111 XZ1 15 10
W111 XZ2.1 25 35
W111 XZ2 35 5
W112 LP1 45 40
W112 JK2 48 35
我想为 dataframe1 创建一个数据透视表,它将给出每个产品的 element2 和 element3 的平均值。其概念是,如果对于特定产品存在样本 XX,则给出 XX 样本的平均值,如果仅存在样本 XZ,则平均值将只是最新 XZ 样本的读数(例如 XZ1、XZ2 和XZ2.1,XZ2.1是最新的)。如果存在除这些 sample 以外的任何东西,请忽略该产品。所以最后我想要
Product element2_avg element3_avg
W100 (40+30)/2=35 (10+40)/2=25
W111 25 35
因此,W112 被忽略。
现在有另一个数据框,其中包含仅包含 XZ 样本的产品,如下所示。
dataframe2 =
Product sample element2 element3
W110 XZ1 20 10
W110 XZ1.1 30 20
W120 XZ1 40 90
W120 XZ3 20 40
W120 XZ2 60 60
W120 XZ2.2 75 90
因此该 dataframe2 的表格将是。
Product element2_avg element3_avg
W110 30 20
W120 20 40
我想要 dataframe1 和 dataframe2 的通用代码,而不是单独的代码。如何做到这一点?
提前致谢。
最佳答案
您可以分 3 部分完成,先获取 XX
,然后获取 XZ
,最后将它们连接起来
先获取 XX
XX_samp = df.loc[df['sample'].str.contains('XX')].groupby('Product').mean()
获取这些产品以便稍后删除
XX_prod = XX_samp.reset_index()['产品'].unique()
获取XZ
XZ_samp = df[df['sample'].str.contains('XZ') & ~df['Product'].isin(XX_prod)].sort_values(['Product', 'sample']).groupby('Product').agg({'element2': 'last', 'element3': 'last'})
最后将它们连接起来
pd.concat([XX_samp, XZ_samp])
你可以把它们放在一个函数中
def product_means(df):
XX_samp = df.loc[df['sample'].str.contains('XX')].groupby('Product').mean()
XX_prod = XX_samp.reset_index()['Product'].unique()
XZ_samp = df[df['sample'].str.contains('XZ') & ~df['Product'].isin(XX_prod)].sort_values(['Product', 'sample']).groupby('Product').agg({'element2': 'last', 'element3': 'last'})
mdf = pd.concat([XX_samp, XZ_samp])
return mdf
product_means(df1)
Product element2 element3
W100 35 25
W111 25 35
product_means(df2)
Product element2 element3
W110 30 20
W120 20 40
关于python - 在数据框中添加列的通用代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59781106/
我使用 AppFuse 创建项目已经有一段时间了。我已经知道有两种方法可以开发 DAO 和 Manager 类: GenericDao/GenericManager 方法 UniversalDao/U
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
在普通的单线程程序中,捕获异常只需要通过try ... catch ... finally ...代码块就可以了。那么,在并发情况下,比如在父线程中启动了子线程,如何在父线程中捕获来自子线程的异常,
假设我有一个这样的界面 interface Example { first_name: string, last_name: string, home_town: string
我已经成为 hg 用户几年了,对此我很高兴! 我必须开始一个我以前从未做过的项目。我们的想法是开发一个具有批处理模式和 GUI 的软件。 因此,批处理模式和 GUI 模式都有共同的源,但每种模式也都包
我可以在Silverlight中使用generic.xaml来设置应用程序中所有TextBlock的样式吗? 我原以为它会起作用,但它没
顶部 map 有 3 个子 map ,每个子 map 都有不同的对象。 像下面的代码,如何将通用添加到 map 顶部? Map top = new ConcurrentHashMap();
我想创建一个hashmap,其中键是接口(interface)A,值是接口(interface)B。然后我想用实现A和B的类来初始化它。是否可以使用java泛型来做到这一点? 也就是说,我想要类似的东
Enum 位于 java.lang.Enum 中,Object 位于 java.lang.Object 中>。那么,为什么 Enum 不是 Object 呢? (我收到一个java.lang.Clas
我有一种方法,check,它有两个 HashMap 作为参数。这些映射的键是 String,值是 String 或 Arraylist。 哪个是更好的解决方案: public static boole
我启动了针对iPhone的应用程序,现在我也想将其应用程序用于iPad。当我开始做iPhone项目时,即使我添加了iPad xib,它也无法正确显示,如何转换我的项目同时适用于iPhone和iPad(
这行代码(代码1)有什么区别 auto l1 = [](auto a) { static int l = 0; std::cout operator() for type const char*) 被
使用 Generic#to,我可以获得 case class 的 HList 表示: import shapeless._ case class F(x: Int, y: String) scala>
我有一个 BiDiMap 类。如何使其通用,不仅接受 String 而且接受 Object 类型的对象作为输入参数,同时保持所有原始函数正常工作。例如,我希望能够使用函数 put() 和 Object
我在编译 foreach 循环时遇到问题。我很确定这是我的泛型处理的问题,因为该错误是对象兼容性问题。我已搜索解决方案,但找不到任何可以解决该问题的内容。 这是定义 Iterable adjList
大约有 6 个 POJO 类(域实体、DTO、DMO)都具有几乎相同的字段。为了从一个对象转换为另一个对象,我传递一个对象并调用它的 getter 将其设置到另一个对象中。 private UserT
有没有什么方法可以创建一个通用的 for 循环,它可以正确地循环遍历数组或对象?我知道我可以编写以下 for 循环,但它也会遍历将添加到数组的其他属性。 for (item in x) { co
我已经有一段时间没有写js了,显然有点生疏了。试图理解以下问题。 getCurrentPosition successCallback 中的警报正确显示纬度,但最后一行警报未定义。为什么我的 clie
请帮助我,我从来没有用 xib 为 iPhone/iPad 制作过通用的 UIViewControllers。如何使用 .m 和 .h 文件以及 _iphone.xib 和 _ipad.xib 创建类
我正在尝试创建一个 createRequest 函数,我可以将其重新用于我的所有网络调用,有些需要发布 JSON 而其他则不需要,所以我正在考虑创建一个采用可选通用对象的函数;理论上是这样的: str
我是一名优秀的程序员,十分优秀!