如何把Dataframe A 的特定数值的列拷贝到 Dataframe B
本帖最后由 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=shuju.loc==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个,没区别。麻烦大神看下哪里出问题 chaxun=shuju.loc==test]
这行是这样,不知为何一楼没显示出 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=shuju.loc==test] 这一句的问题是,你的jieguo['名称']从哪来的变量,怎么突然出现了jieguo,以及如果想获取某行可以直接.loc获取;拷贝的话用.loc.copy()
chaxun=shuju.loc==test] lassiter 发表于 2023-1-28 10:05
shuju = pd.read_excel(path+'/'+filename)
你的shuju只是读了这个xlsx文件,你还没有指定是哪个工作表, ...
谢谢提醒,搞定了
页:
[1]