返回顶部
首页 > 资讯 > 精选 >dataframe两列相乘构造新特征的示例分析
  • 447
分享到

dataframe两列相乘构造新特征的示例分析

2023-06-15 03:06:40 447人浏览 安东尼
摘要

这篇文章主要介绍了dataframe两列相乘构造新特征的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。假如我们要构建新特征b目的是从a中筛选出数值在4~6之间的数据,

这篇文章主要介绍了dataframe两列相乘构造新特征的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

假如我们要构建新特征b

目的是从a中筛选出数值在4~6之间的数据,如果符合就是True,否则就是False。

那么代码如下

import pandas as pdlists=pd.DataFrame({'a':[1,2,3,4,5,6,7,8,9]})lists['b']=(lists['a']<6).mul(lists['a']>4)

补充:dataframe求两列的相乘,再将输出为新的一列

看代码吧~

df["new"]=df3["rate"]*df3["duration"]

new为新的一列的列名

rate和duration为需要相乘的列

加,减,乘,除都适用!

补充:DataFrame衍生新特征操作

1.DataFrame中某一列的值衍生为新的特征

#将LBL1特征的值衍生为one-hot形式的新特征piao=df_train_log.LBL1.value_counts().index#先构造一个临时的dfdf_tmp=pd.DataFrame({'USRID':df_train_log.drop_duplicates('USRID').USRID.values})#将所有的新特征列都置为0for i in piao:    df_tmp['PIAO_'+i]=0#进行分组便利,有这个特征就置为1,原数据每个USRID有多条记录,所以分组统计group=df_train_log.groupby(['USRID'])for k in group.groups.keys():    t = group.get_group(k)    id=t.USRID.value_counts().index[0]    tmp_list=t.LBL1.value_counts().index    for j in tmp_list:        df_tmp['PIAO_'+j].loc[df_tmp.USRID==id]=1

2.分组统计,选出同一USRID下该变量中出现次数最多的值项

group=df_train_log.groupby(['USRID'])lt=[]list_max_lbl1=[]list_max_lbl2=[]list_max_lbl3=[]for k in group.groups.keys():    t = group.get_group(k)    #通过value_counts找出出现次数最多的项    argmx = np.argmax(t['EVT_LBL'].value_counts())    lbl1_max=np.argmax(t['LBL1'].value_counts())    lbl2_max=np.argmax(t['LBL2'].value_counts())    lbl3_max=np.argmax(t['LBL3'].value_counts())    list_max_lbl1.append(lbl1_max)    list_max_lbl2.append(lbl2_max)    list_max_lbl3.append(lbl3_max)    #只留下出现次数最多的项    c = t[t['EVT_LBL']==argmx].drop_duplicates('EVT_LBL')    #放入list中    lt.append(c)#构造一个新的dfdf_train_log_new = pd.concat(lt)#另外又构造了三个特征,LBL1-LBL3分别出现次数最多的项df_train_log_new['LBL1_MAX']=list_max_lbl1df_train_log_new['LBL2_MAX']=list_max_lbl2df_train_log_new['LBL3_MAX']=list_max_lbl3

3.衍生出某天是否发生的ont-hot新特征

#创造临时df,星期三,星期六,星期七,都默认置为0df_day=pd.DataFrame({'USRID':df_train_log.drop_duplicates('USRID').USRID.values})df_day['weekday_3']=0df_day['weekday_6']=0df_day['weekday_7']=0#分组统计,有就置为1,没有置为0group=df_train_log.groupby(['USRID'])for k in group.groups.keys():    t = group.get_group(k)    id=t.USRID.value_counts().index[0]    tmp_list=t.occ_dayofweek.value_counts().index    for j in tmp_list:        if j==3:            df_day['weekday_3'].loc[df_tmp.USRID==id]=1        elif j==6:            df_day['weekday_6'].loc[df_tmp.USRID==id]=1        elif j==7:            df_day['weekday_7'].loc[df_tmp.USRID==id]=1

4.查看用户一共停留在APP上多少秒,共有几天看了APP

dataframe两列相乘构造新特征的示例分析

#首先将日期转化为时间戳,并赋予一个新特征tmp_list=[]for i in df_train_log.OCC_TIM:    d=datetime.datetime.strptime(str(i),"%Y-%m-%d %H:%M:%S")    evt_time = time.mktime(d.timetuple())    tmp_list.append(evt_time)df_train_log['time']=tmp_list#每下一行减去上一行,得到app停留时间df_train_log['diff_time']=df_train_log.time-df_train_log.time.shift(1)#构造一个新的dataFrame,分组得到查看app的天数df_time=pd.DataFrame({'USRID':df_train_log.drop_duplicates('USRID').USRID.values})#有几天查看df_time['days']=0group=df_train_log.groupby(['USRID'])for k in group.groups.keys():    t = group.get_group(k)    id=set(t.USRID).pop()    df_time['days'].loc[df_time.USRID==id]= len(t.occ_day.value_counts().index)#去掉一些异常时间戳,比如间隔两天的相减,肯定不合适,na的也去掉了df_train_log=df_train_log[(df_train_log.diff_time>0)&(df_train_log.diff_time<8000)]#累计停留时间group_stayTime=df_train_log['diff_time'].groupby(df_train_log['USRID']).sum()#创造新的dfdf_tmp=pd.DataFrame({'USRID':list(group_stayTime.index.values),'stay_time':list(group_stayTime.values)})#合并成一个新的dfdf=pd.merge(df_time,df_tmp,on=['USRID'],how='left')#合并后,缺失的停留时间,置为0df.fillna(0,axis=1,inplace=True)

dataframe两列相乘构造新特征的示例分析

感谢你能够认真阅读完这篇文章,希望小编分享的“dataframe两列相乘构造新特征的示例分析”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网精选频道,更多相关知识等着你来学习!

--结束END--

本文标题: dataframe两列相乘构造新特征的示例分析

本文链接: https://lsjlt.com/news/277131.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • dataframe两列相乘构造新特征的示例分析
    这篇文章主要介绍了dataframe两列相乘构造新特征的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。假如我们要构建新特征b目的是从a中筛选出数值在4~6之间的数据,...
    99+
    2023-06-15
  • 浅谈dataframe两列相乘构造新特征
    假如我们要构建新特征b 目的是从a中筛选出数值在4~6之间的数据,如果符合就是True,否则就是False。 那么代码如下 import pandas as pd lists=p...
    99+
    2024-04-02
  • LeetCode中两数相加的示例分析
    小编给大家分享一下LeetCode中两数相加的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!题目描述给定两个非空链表来代表两个非负整数。数字最高位位于链表...
    99+
    2023-06-19
  • HTML5新特性的示例分析
    小编给大家分享一下HTML5新特性的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!   一:新增的功能   更加语义...
    99+
    2024-04-02
  • ECMAScript6新特性的示例分析
    这篇文章将为大家详细讲解有关ECMAScript6新特性的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。箭头函数function() 函数的简写表示法,但它不绑定...
    99+
    2024-04-02
  • C语言中字符串相乘的示例分析
    这篇文章主要介绍C语言中字符串相乘的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一. 分析思路示例:我们把每一个数都看成是一个字符串,每一个元素为十进制数字所对应的字 符,由于是后面的元素先进行运算,故我们...
    99+
    2023-06-29
  • Python基于Pytorch特征图提取的示例分析
    这篇文章给大家分享的是有关Python基于Pytorch特征图提取的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。简述为了方便理解卷积神经网络的运行过程,需要对卷积神经网络的运行结果进行可视化的展示。大致...
    99+
    2023-06-29
  • css3中新特性的示例分析
    这篇文章主要为大家展示了“css3中新特性的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css3中新特性的示例分析”这篇文章吧。css3被拆分成如下的...
    99+
    2024-04-02
  • JDK-12新特性的示例分析
    这篇文章主要介绍了JDK-12新特性的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。说明目前JDK12已经发布,而且我估计大多数人还在使用JDK8,但是做程序开发的人...
    99+
    2023-06-20
  • Vue进阶构造属性的示例分析
    小编给大家分享一下Vue进阶构造属性的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、Directive 自定义指令在 Vue 框架下的代码中,很少用到...
    99+
    2023-06-15
  • Vue3中teleport新特性的示例分析
    Vue3中teleport新特性的示例分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Vue鼓励我们通过将UI和相关行为封装到组件中来构...
    99+
    2024-04-02
  • Java8新特性Stream流的示例分析
    这篇文章主要介绍Java8新特性Stream流的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!什么是Stream流?Stream流是数据渠道,用于操作数据源(集合、数组等)所生成的元素序列。Stream的优点...
    99+
    2023-05-30
    java8 stream流
  • 阶乘相关的算法及其C++实现的示例分析
    本篇文章为大家展示了阶乘相关的算法及其C++实现的示例分析,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。阶乘指从1乘以2乘以3乘以4一直乘到所要求的数。C++中的阶乘亦是如此。有关阶乘的算法,不外乎...
    99+
    2023-06-17
  • golang特有程序结构的示例分析
    这篇文章将为大家详细讲解有关golang特有程序结构的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Go语言的由来Go语言亦叫Golong语言,是由谷歌Goggle公司推出。Go语言的主要开发者有...
    99+
    2023-06-15
  • CentOS7.0命令更新新版特性的示例分析
    小编给大家分享一下CentOS7.0命令更新新版特性的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!查看系统版本信息#uname -a#cat /etc/...
    99+
    2023-06-10
  • ECMAScript6新特性之let、const的示例分析
    这篇文章将为大家详细讲解有关ECMAScript6新特性之let、const的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。es6中的新特性之“let”。首先,这...
    99+
    2024-04-02
  • ES9中新特性Async iteration的示例分析
    这篇文章将为大家详细讲解有关ES9中新特性Async iteration的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在ES6中,引入了同步iteration的概念,随着ES8中的Async操作...
    99+
    2023-06-14
  • javascript面向对象三大特征之继承的示例分析
    小编给大家分享一下javascript面向对象三大特征之继承的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!具体如下:继...
    99+
    2024-04-02
  • javascript面向对象三大特征之封装的示例分析
    这篇文章主要介绍了javascript面向对象三大特征之封装的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体如下:封装封装(En...
    99+
    2024-04-02
  • python机器学习中特征工程算法的示例分析
    这篇文章主要为大家展示了“python机器学习中特征工程算法的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“python机器学习中特征工程算法的示例分析”这篇文章吧。一、机器学习概述机器...
    99+
    2023-06-25
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作