鱼C论坛

 找回密码
 立即注册
查看: 3379|回复: 3

[已解决]如何把Dataframe A 的特定数值的列拷贝到 Dataframe B

[复制链接]
发表于 2023-1-27 21:04:33 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 skyhouse 于 2023-1-27 22:03 编辑

import pandas as pd
import numpy as np
import xlwt
import openpyxl

filename = '数据.xlsx'
path = 'E://实验数据'
shuju = pd.read_excel(path+'/'+filename)
chaxun = pd.DataFrame(columns=shuju.columns)
i = 0
test = input('输入名称:')
while test != str('b'):
    chaxun[i]=shuju.loc[jieguo[‘名称']==test]
    i+=1
    test = input('输入名称:')
    print(chaxun)

想要在已有的Dataframe A 中读取名称的列为输入的名称时,把一整行拷贝到另外一个Dataframe中,但运行中出现错误
ValueError: Cannot set a DataFrame with multiple columns to the single column 0

我对比过(print过)Dataframe A 跟 B 的colunms都是6个,没区别。麻烦大神看下哪里出问题
最佳答案
2023-1-28 10:05:02
shuju = pd.read_excel(path+'/'+filename)
你的shuju只是读了这个xlsx文件,你还没有指定是哪个工作表,用
shuju = pd.read_excel(path+'/'+filename,sheet_name=0)指定工作表,但如果你的xlsx文件中就1个工作表,那当我没说。

chaxun = pd.DataFrame(columns=shuju.columns)这句中的columns指定的是列索引,就是第一行的内容,看你题目的本意是想读取名称的列是你的输入时,把一整行拷贝,那你这里应该用index指定行索引,然后找到你想拷贝的行,将之拷出;

chaxun[i]=shuju.loc[jieguo[‘名称']==test] 这一句的问题是,你的jieguo['名称']从哪来的变量,怎么突然出现了jieguo,以及如果想获取某行可以直接.loc[test ,:]获取;拷贝的话用.loc[test ,:].copy()

chaxun=shuju.loc[jieguo[‘名称']==test]
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2023-1-27 22:04:15 | 显示全部楼层
    chaxun[i]=shuju.loc[jieguo[‘名称']==test]
这行是这样,不知为何一楼没显示出[i]
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-1-28 10:05:02 | 显示全部楼层    本楼为最佳答案   
shuju = pd.read_excel(path+'/'+filename)
你的shuju只是读了这个xlsx文件,你还没有指定是哪个工作表,用
shuju = pd.read_excel(path+'/'+filename,sheet_name=0)指定工作表,但如果你的xlsx文件中就1个工作表,那当我没说。

chaxun = pd.DataFrame(columns=shuju.columns)这句中的columns指定的是列索引,就是第一行的内容,看你题目的本意是想读取名称的列是你的输入时,把一整行拷贝,那你这里应该用index指定行索引,然后找到你想拷贝的行,将之拷出;

chaxun[i]=shuju.loc[jieguo[‘名称']==test] 这一句的问题是,你的jieguo['名称']从哪来的变量,怎么突然出现了jieguo,以及如果想获取某行可以直接.loc[test ,:]获取;拷贝的话用.loc[test ,:].copy()

chaxun=shuju.loc[jieguo[‘名称']==test]
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-1-28 17:57:33 | 显示全部楼层
lassiter 发表于 2023-1-28 10:05
shuju = pd.read_excel(path+'/'+filename)
你的shuju只是读了这个xlsx文件,你还没有指定是哪个工作表, ...

谢谢提醒,搞定了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-16 08:26

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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