Python数据处理:如何自动插入相关数据到工作表中

复制代码
    def price_insert_15_20_30(self,df,column):
        df = df.rename(columns={column:'sku'})
        data = pd.read_excel(r'C:\Users\wangkejun\Desktop\orderadjust\tempdata\caculatetemp.xlsx')
        data['sku'] = df['sku']
        columns = list(data.columns)
        data = pd.merge(data,df,on=['sku'],how='left',suffixes=['','_r'])

        data['平台佣金率'] = data.apply(lambda x:x['平台佣金率补充'] if pd.notna(x['平台佣金率补充']) else x['平台佣金率'],axis=1)
        data['采购价'] = data.apply(lambda x:x['采购价补充'] if pd.notna(x['采购价补充']) else x['采购价'],axis=1)
        data['实重'] = data.apply(lambda x:x['计费重补充'] if pd.notna(x['计费重补充']) else x['实重'],axis=1)


        data = data.loc[:,columns]
        df = data.loc[:,['sku']]
        for i in [0.15,0.2,0.3]:
            datatemp = data.copy()
            datatemp['毛利率'] = i
            datatemp = datatemp.apply(self.calculate_price, axis=1)
            title = f'{i*100}%'
            datatemp = datatemp.rename(columns = {'price':title})
            datatemp = datatemp.loc[:,['sku','平台佣金率', '采购价', '计费重',title]]
            df = pd.merge(df,datatemp,how='left',on=['sku'])

        df = df.rename(columns={'sku':column})
        return df   
      
 # 费用相关数据
dfall['系统SKU'] = dfall['系统SKU'].astype('object')
dfbasicprice = pd.merge(dfall.loc[:,['系统SKU']],dfbasic,how='left',on=['系统SKU'])

dfbasicprice = dfbasicprice.dropna(subset=['系统SKU'])

dfbasicprice = caculate().price_insert_15_20_30(dfbasicprice,'系统SKU')

dfzongbiaojilu= dfbasicprice.loc[:, ['系统SKU', '平台佣金率', '采购价', '计费重']]
dfzongbiaojilu2= dfbasic.loc[:, ['系统SKU', '平台佣金率补充', '采购价补充', '计费重补充']]


merged_df = dfzongbiaojilu.merge(dfzongbiaojilu2, on='系统SKU')

        # 去除NaN值
merged_df = merged_df.dropna()

        # 插入数据到工作表
self.worksheetinsert(merged_df, number=1, worksheetid=excelsheet['总表新品数据记录表']) 

具体来说,你首先将 dfall['系统SKU'] 的数据类型更改为 'object',然后使用 pd.merge() 函数将 dfbasicdfall 进行左连接,基于共同的列 '系统SKU'。接下来,你删除了包含 NaN 值的行,并将结果保存在 dfbasicprice 中。

然后,你对 dfbasicprice 调用了 caculate().price_insert_15_20_30(dfbasicprice, '系统SKU'),并传入了参数 '系统SKU'。这应该是一个自定义的计算函数,根据传入的 DataFrame 和列名进行价格计算和插入操作。请确保该函数能够正常运行,并返回预期的结果。

接下来,你从 dfbasicpricedfbasic 中选择了特定的列,并分别保存在 dfzongbiaojiludfzongbiaojilu2 中。

最后,你使用 merge() 函数将 dfzongbiaojiludfzongbiaojilu2 基于列 '系统SKU' 进行合并,并保存在 merged_df 中。最后,你删除了包含 NaN 值的行,并将结果插入到工作表中

相关推荐
MY_TEUCK3 小时前
【Java 后端】SpringBoot 登录认证与会话跟踪实战(JWT + Filter/Interceptor)
java·开发语言·spring boot
QQ2422199794 小时前
基于python+微信小程序的家教管理系统_mh3j9
开发语言·python·微信小程序
沐知全栈开发4 小时前
JavaScript 条件语句
开发语言
RSTJ_16254 小时前
PYTHON+AI LLM DAY THREETY-SEVEN
开发语言·人工智能·python
郝学胜-神的一滴4 小时前
深度学习优化核心:梯度下降与网络训练全解析
数据结构·人工智能·python·深度学习·算法·机器学习
Aision_4 小时前
Agent 为什么需要 Checkpoint?
人工智能·python·gpt·langchain·prompt·aigc·agi
清水白石0084 小时前
《Python性能深潜:从对象分配开销到“小对象风暴”的破解之道(含实战与最佳实践)》
开发语言·python
Je1lyfish5 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
Brilliantwxx5 小时前
【C++】 vector(代码实现+坑点讲解)
开发语言·c++·笔记·算法
野生技术架构师5 小时前
2026年最全Java面试题及答案汇总(建议收藏,面试前看这篇就够了)
java·开发语言·面试