彭彭和丁满_ 2021-04-21 15:47 采纳率: 100%
浏览 403
已采纳

python for循环写入csv表格添加数据的时候会被最后的数据覆盖

在爬虫或者数据分析过程中,使用for循环添加的数据被最后一次循环覆盖参数

如下尝试其他博主的方式也没有改变。

for的循环写入不被覆盖需要用‘a’写入方法,我原来用的‘w’所以被覆盖了

filename = 'allserver.txt' 
with open(filename,'a',encoding='utf-8') as f: 
    f.writelines(dates + '*'*50 + '\n')

我需要的操作是提取每一合约 进行数据分析

for循环代码如下:

import pandas as pd
data=pd.read_csv(r"/Users/bingtangdunxueli期货交易记录.csv",encoding="gbk")
for i in data["合约"]:
    print(i)
    data_gender = data[['日期','品种','合约','合约乘数','买开手数','买开均价']]
    data_gender_re = data_gender[data_gender.notnull()]
    FF = data_gender_re.loc[(data_gender_re['合约'] == i)]
    filename = '/Users/bingtangdunxueli/quanbu.csv'
    with open(filename,'a',encoding='utf-8') as f:
       f.writelines(FF)

结果仍然是最后数据覆盖

 

 

  • 写回答

6条回答 默认 最新

  • 关注
    import pandas as pd
    data=pd.read_csv(r"/Users/bingtangdunxueli期货交易记录.csv",encoding="gbk")
    filename = '/Users/bingtangdunxueli/quanbu.csv'
    with open(filename,'w',encoding='utf-8') as f:
        f.write("日期,品种,合约,合约乘数,买开手数,买开均价\n")
        for i in data["合约"]:
            print(i)
            data_gender = data[['日期','品种','合约','合约乘数','买开手数','买开均价']]
            data_gender_re = data_gender[data_gender.notnull()]
            FF = data_gender_re.loc[(data_gender_re['合约'] == i)]
            for li in FF.values.tolist():
                s = ",".join(map(str,li))
                f.write(s+"\n")
    

    这样看看

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

报告相同问题?

悬赏问题

  • ¥15 wamp3.3.5安装完成后图标正常显示绿色,鼠标左右键点击图标均无反应。求解决方法。
  • ¥15 鼠标点击的这条记录了什么?
  • ¥15 在写pid调速的程序时,电机始终维持最大速度
  • ¥15 请问如何查看手机root记录?
  • ¥15 商城小程序订单号重复
  • ¥15 学校优化算法sbo和蚁群算法怎么结合
  • ¥21 matlab怎么求时域信号的二阶导数
  • ¥15 判断两个表是否完全相同
  • ¥15 java map类型数据格式,如何快速通过前缀匹配元素
  • ¥15 stc12c5a60s2、QMC5883L、LCD1602组合测量磁场所需程序