如何使用python将随机数转换为十六进制颜色?

如何使用python将随机数转换为十六进制颜色?,python,pandas,hex,Python,Pandas,Hex,假设我有一个包含以下列的数据框架: import pandas as pd df = pd.DataFrame({ 'strings': ['Wut?', 'Random', 'Citruna', 'FlatEarth', 'ElonMusk'], 'postcode': [97700, 04130, 33210, 00520, 97700]}) 问题: 我想创建一个新列,该列将采用df[“postcode”]中的值,并将其用作种子,以生成随机的十六进制颜色。如何做到这一点

假设我有一个包含以下列的数据框架:

import pandas as pd 

df = pd.DataFrame({
    'strings': ['Wut?', 'Random', 'Citruna', 'FlatEarth', 'ElonMusk'],
    'postcode': [97700, 04130, 33210, 00520, 97700]})
问题:
我想创建一个新列,该列将采用df[“postcode”]中的值,并将其用作种子,以生成随机的十六进制颜色。如何做到这一点?

下面是一个示例,说明如何应用于您的问题

import numpy as np
import pandas as pd

def color(seed):
    np.random.seed(seed)
    return '#%02X%02X%02X' % tuple(np.random.randint(0, 255, 3))

df = pd.DataFrame({
    'strings': ['Wut?', 'Random', 'Citruna', 'FlatEarth', 'ElonMusk'],
    'postcode': ['97700', '04130', '33210', '00520', '97700']
})

df['color'] = df['postcode'].astype(int).apply(lambda x: color(x))

print(df)

#      strings postcode    color
# 0       Wut?    97700  #E60997
# 1     Random    04130  #FEDC98
# 2    Citruna    33210  #218F90
# 3  FlatEarth    00520  #AC6B9B
# 4   ElonMusk    97700  #E60997