Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/python-3.x/16.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/ruby-on-rails-3/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 使用lambda函数添加数据帧列_Python_Python 3.x_Pandas_Dataframe_Lambda - Fatal编程技术网

Python 使用lambda函数添加数据帧列

Python 使用lambda函数添加数据帧列,python,python-3.x,pandas,dataframe,lambda,Python,Python 3.x,Pandas,Dataframe,Lambda,我试图用随机生成的两个大写字母的代码向Pandas数据框添加一列。对于随机代码生成,我编写了一个函数,但当我将其添加到数据帧时,结果只给出NaN。你知道怎么解决这个问题吗 import pandas as pd import random import string def generateCode(): return random.choice(string.ascii_uppercase) + random.choice(string.ascii_uppercase) cars

我试图用随机生成的两个大写字母的代码向Pandas数据框添加一列。对于随机代码生成,我编写了一个函数,但当我将其添加到数据帧时,结果只给出NaN。你知道怎么解决这个问题吗

import pandas as pd
import random
import string

def generateCode():
    return random.choice(string.ascii_uppercase) + random.choice(string.ascii_uppercase)

cars = {'Brand': ['Honda Civic','Toyota Corolla','Ford Focus','Audi A4'],
        'Price': [22000,25000,27000,35000]
        }
df = pd.DataFrame(cars, columns = ['Brand', 'Price'])

df['Code'] = df.apply(lambda x: generateCode())

print(df)
给出输出:

            Brand  Price Code
0     Honda Civic  22000  NaN
1  Toyota Corolla  25000  NaN
2      Ford Focus  27000  NaN
3         Audi A4  35000  NaN
谢谢你的帮助

用于每个值的处理:

df['Code'] = df['Brand'].apply(lambda x: generateCode())

print(df)
            Brand  Price Code
0     Honda Civic  22000   AY
1  Toyota Corolla  25000   EN
2      Ford Focus  27000   VN
3         Audi A4  35000   ZZ
或使用轴=1的
进行每行处理:

df['Code'] = df.apply(lambda x: generateCode(), axis=1)

print(df)
            Brand  Price Code
0     Honda Civic  22000   AY
1  Toyota Corolla  25000   EN
2      Ford Focus  27000   VN
3         Audi A4  35000   ZZ

别问我为什么,但这确实奏效了:

import pandas as pd
import random
import string

def generateCode():
    print(random.choice(string.ascii_uppercase) + random.choice(string.ascii_uppercase))
    return random.choice(string.ascii_uppercase) + random.choice(string.ascii_uppercase)

cars = {'Brand': ['Honda Civic','Toyota Corolla','Ford Focus','Audi A4'],
        'Price': [22000,25000,27000,35000]
        }
df = pd.DataFrame(cars, columns = ['Brand', 'Price'])

df['Code'] = df.Brand.map(lambda x: generateCode())

print(df)

如果有人能解释为什么这样做,我会很感激的

事实上,我一直在打印,我认为问题在于你没有指定一列,所以它返回了整行,而不是每行值都是一个序列
df.Brand.apply(lambda x:generateCode())
,这也可以通过添加
df['code']=df.apply(lambda x:generateCode(),axis=1)