gpt4 book ai didi

Python .read() 没有将 CSV 正确读入字符串

转载 作者:太空宇宙 更新时间:2023-11-04 01:07:55 31 4
gpt4 key购买 nike

我正在尝试使用 MWS Api 将制表符分隔的 .txt 文件推送到亚马逊。下面的代码有效:

    from boto.mws import connection
import time

# Amazon US MWS ID
MarketPlaceID = 'mpid'
MerchantID = 'merchantid'
AccessKeyID = 'akid'
SecretKey = 'secretkey'

conn = connection.MWSConnection(
aws_access_key_id=AccessKeyID,
aws_secret_access_key=SecretKey,
Merchant=MerchantID)

feed = conn.submit_feed(
FeedType='_POST_FLAT_FILE_PRICEANDQUANTITYONLY_UPDATE_DATA_',
PurgeAndReplace=False,
MarketplaceIdList=[MarketPlaceID],
content_type='text/tab-separated-values',
FeedContent="""SKU QUANTITY
ABC 123"""
)

使用上述方法,ABC 的数量设置为 123。但是,当我尝试从制表符分隔文件中读取相同数据到 feed_dat 并将 feed_dat 传递到 FeedContent 时,我收到一条错误消息,指出我的 header 已关闭。

feed_content = open('/Scripts/data.txt', 'rb')
print feed_content.read()
feed_dat = feed_content.read()

我感觉 .read() 方法正在破坏我的制表符分隔数据。我可以复制/粘贴前几行并通过将数据用三引号引起来将它们推送到 API,但我似乎无法将选项卡文件读取到变量并以这种方式推送。我也尝试过使用 .encode('utf-8') 对文件进行编码,但没有成功。感谢您的意见!

谢谢,

C

最佳答案

您正在调用 feed_content.read() 两次。第一次,整个内容被读取,光标现在指向文件的末尾。再次调用 feed_content.read() 将返回一个空字符串,因为已经到达文件末尾。

请参阅 read() 的文档举个例子。

一个简单的解决方法是在分配后移动 print,以避免尝试调用 read() 两次:

feed_content = open('/Scripts/data.txt', 'rb')
feed_dat = feed_content.read()
print feed_dat # print has been moved after the assignment

关于Python .read() 没有将 CSV 正确读入字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29402585/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com