吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1808|回复: 9
收起左侧

[讨论] pandas中怎么一起赋值两列?

[复制链接]
ymhld 发表于 2020-5-17 13:48
本帖最后由 ymhld 于 2020-5-17 16:00 编辑

我想增加两列,序号和列名,一个等于索引,一个等于p列,用两行赋值是可以写,能写到一个语句里吗?
用过data[['序号','列名']]=data.apply(lambda x :('序号‘,’列名') axis=1,result_type='expand')
但只能把文字赋值里面,不能直接等于index 和P列
有没有data[['序号','列名']]=data[index,'p']这样的简洁写法?
data[['序号','列名']]=data[['p','x']] 这样是可以的,但怎么把index加进去?

[Python] 纯文本查看 复制代码
import numpy as np
import pandas as pd
from pandas import Series

chengji = [['N', 95, 0], ['N', 100, 88], ['N', 88, 100], ['N', 66, 0]]
data = pd.DataFrame(chengji, columns=['p', 'x', 'g'])
data['序号']=data.index
data['列名']=data['p']
print(data)

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

头像被屏蔽
Ryan袁奥 发表于 2020-5-17 15:19
提示: 作者被禁止或删除 内容自动屏蔽
 楼主| ymhld 发表于 2020-5-17 15:38
Ryan袁奥 发表于 2020-5-17 15:19
pandas 使用apply可同时处理两列数据

[mw_shl_code=python,true]import numpy as np

这是处理两列,有没有新建两列一起再用index和其它列赋值的方法?
Qnly_genius 发表于 2020-5-17 16:45
[Python] 纯文本查看 复制代码
data[['序号','列名']]=pd.concat([pd.Series(data.index), data['p']], axis=1)
Qnly_genius 发表于 2020-5-17 16:49
[Python] 纯文本查看 复制代码
data['序号'], data['列明'] = data.index, data['p']

这样也行
 楼主| ymhld 发表于 2020-5-17 16:54

好吧,算你胜了
Qnly_genius 发表于 2020-5-17 16:56
ymhld 发表于 2020-5-17 16:54
好吧,算你胜了

你这个需求列数多一点的话,用concat就挺好
 楼主| ymhld 发表于 2020-5-17 17:03
Qnly_genius 发表于 2020-5-17 16:56
你这个需求列数多一点的话,用concat就挺好

找了好多办法,但index除了这样赋值外,都用不上
rsnodame 发表于 2020-5-17 20:49
我也觉得concat比较合适…………把索引移入DataFrame可以试试 df.reset_index(drop=False) ?

免费评分

参与人数 1吾爱币 +1 热心值 +1 收起 理由
ymhld + 1 + 1 热心回复!

查看全部评分

 楼主| ymhld 发表于 2020-5-17 21:08
rsnodame 发表于 2020-5-17 20:49
我也觉得concat比较合适…………把索引移入DataFrame可以试试 df.reset_index(drop=False) ?

看来是直接用不行了,曲线救国吧,不行写就写两行吧
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-26 17:38

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表