是树先生啊 2023-08-30 16:02 采纳率: 50%
浏览 25
已结题

如何使用脚本将xlsx表格数据进行拼接?

使用脚本将xlsx表格数据进行拼接,将下图格式

img

转换为这种格式

img

  • 写回答

10条回答 默认 最新

  • chuifengde 2023-08-30 17:39
    关注

    这个意思?

    import pandas as pd
    
    def get_df(series, *col_name):
        series = series[1].tolist()
        d = pd.DataFrame()
        
        for j in range(3, 6):
            dict_data = {}
            tt = series[j]
            if tt:
                t =[col_name[j]+ i for i in tt.split(',')]
                len_ = len(t)
                dict_data['编码'] = [col_name[j]] * len_
                dict_data['号段'] = t
                dict_data['省份'] = [series[0] ]* len_
                dict_data['城市'] = [series[1]] * len_
                dict_data['运营商'] = ['中国广电'] * len_
                dt =  pd.DataFrame(data = dict_data)
                d = pd.concat([d, dt], axis = 0)
                
        return d
            
    
    data = {'省份': ['安徽'] * 10,
            '城市': ['滁州', '合肥', '蚌埠', '芜湖', '淮南', '马鞍山', '安庆', '宿州', '阜阳', '亳州'],
            '城市区号': list(range(550, 559)) + [558],
            '1920': ['550,640,650', '551,560,565,569,644,651', '552, 642,652', '553,643,653', '554', '555,655,645', '556,646,656', '557,647,657', '558,568,641,648,658,659,649', '567'],
            '1921': ['550,640', '551,560,565,641', '552', '553,643', '554,569', '555', '556,646', '557,647', '648', '558,567,642,645'],
            '1922': ['', '350,401', '', '', '', '', '', '', '354,403', ''],
            }
    df = pd.DataFrame(data)
    print(df)
    df_res = pd.DataFrame()
    for dft in df.iterrows() :
        res = get_df(dft, *tuple(df.columns))
        res = res.reset_index(drop = True)
        df_res = pd.concat([df_res,res],axis=0)
    df_res = df_res.reset_index(drop = True)
    print(df_res)
    
    

    结果

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(9条)

报告相同问题?

问题事件

  • 系统已结题 9月8日
  • 已采纳回答 8月31日
  • 赞助了问题酬金15元 8月30日
  • 创建了问题 8月30日

悬赏问题

  • ¥15 软件供应链安全是跟可靠性有关还是跟安全性有关?
  • ¥15 电脑蓝屏logfilessrtsrttrail问题
  • ¥20 关于wordpress建站遇到的问题!(语言-php)(相关搜索:云服务器)
  • ¥15 【求职】怎么找到一个周围人素质都很高不会欺负他人,并且未来月薪能够达到一万以上(技术岗)的工作?希望可以收到写有具体,可靠,已经实践过了的路径的回答?
  • ¥15 Java+vue部署版本反编译
  • ¥100 对反编译和ai熟悉的开发者。
  • ¥15 带序列特征的多输出预测模型
  • ¥15 Python 如何安装 distutils模块
  • ¥15 关于#网络#的问题:网络是从楼上引一根网线下来,接了2台傻瓜交换机,也更换了ip还是不行
  • ¥15 资源泄露软件闪退怎么解决?