ado*_*x56 5 python trading python-3.x ebay-api
这是我的设置:
Python 3.4
使用Trading API
试图打电话给eBay的"VerifyAddItem"
我标记了我在哪里得到错误,PicURL并且我正在尝试发布多个带有多个URL的图片.我目前只是尝试了两张图片让我们说http://i.ebayimg.com/picture1和http://i.ebayimg.com/picture2.(我意识到这些不是真实的图片,但这不是我遇到的问题的一部分)
eBay API Documentations声明To specify multiple pictures, send each URL in a separate, PictureDetails.PictureURL element. The first URL passed in will be the Gallery image and appears on the View Item page.所以我尝试通过以下两行无济于事:
"PictureDetails": {"PictureURL": ["http://i.ebayimg.com/picture1",
                                  "http://i.ebayimg.com/picture2"]}
和
"PictureDetails": [{"PictureURL": "http://i.ebayimg.com/picture1"},
                   {"PictureURL": "http://i.ebayimg.com/picture2"}]
我分别从eBay的连接中得到以下错误:
VerifyAddItem: Class: RequestError, Severity: Error, Code: 37, Input data is invalid. 
Input data for tag <Item.PictureDetails.PictureURL[2]> is invalid or missing. Please 
check API documentation.
和
VerifyAddItem: Class: RequestError, Severity: Error, Code: 37, Input data is invalid. 
Input data for tag <Item.PictureDetails[2].PictureURL> is invalid or missing. Please 
check API documentation.
不幸的是,我已经没有想法了.请帮忙!这是完整的字典,不要担心逻辑,因为我已经验证其他一切正常.
api = Trading(config_file="ebay.yaml", warnings=False)
    myitem = {
        "Item": {
            "Title": Title,
            "Description": Description,
            "PrimaryCategory": {"CategoryID": p.CategoryValue},
            "StartPrice": str(p.Price_sbox.value()),
            "CategoryMappingAllowed": "true",
            "Country": "US",
            "ConditionID": CatID,
            "ConditionDescription": p.CondDetail_tedit.toPlainText(),
            "Currency": "USD",
            "DispatchTimeMax": "1",
            "ListingDuration": "GTC",
            "ListingType": "FixedPriceItem",
            "PaymentMethods": "PayPal",
            "PayPalEmailAddress": PayPal,
            #############################
            ###This is where I get the Error
            #############################
            "PictureDetails": PicURL,
            "PostalCode": ZipCode,
            "Quantity": str(p.Quantity_sbox.value()),
            "ReturnPolicy": {
                "ReturnsAcceptedOption": "ReturnsAccepted",
                "RefundOption": "MoneyBack",
                "Description": "14 days money back, you pay return shipping",
                "ReturnsWithinOption": "Days_14",
                "ShippingCostPaidByOption": "Buyer" },
            "ShippingDetails": {
                "ShippingType": "Calculated",
                "PaymentInstructions": "1 business days of handling time, usually shipped next day. Make sure your address is correct, especially when shipping to foreign countries.",
                "ShippingServiceOptions": {
                    "FreeShipping": FreeShip,
                    "ShippingService": ShipService
                    },
                "CalculatedShippingRate": {"OriginatingPostalCode": ZipCode} },
            "ShippingPackageDetails": {
                "MeasurementUnit": "English",
                "WeightMajor": str(p.WeightLbs_sbox.value()),
                "WeightMinor": str(p.WeightOz_sbox.value()),
                "PackageDepth": str(p.DimensionH_sbox.value()),
                "PackageLength": str(p.DimensionL_sbox.value()),
                "PackageWidth": str(p.DimensionW_sbox.value()),
                "ShippingPackage": "PackageThickEnvelope"},
            "ShipToLocations": "Worldwide",
            "Site": "US",
            "SKU": p.ItemID_ledit.text() } }
    IntShip = []
    boolint = False
    if(p.IntShip1_chbox.isChecked()):
        IntShip.append('USPSPriorityMailInternational')
        boolint = True
    if(p.IntShip2_chbox.isChecked()):
        IntShip.append('USPSPriorityMailInternationalLargeFlatRateBox')
        boolint = True
    if(boolint):
        myitem['Item']['ShippingDetails']['ShippingServiceOptions']['InternationalShippingServiceOption'] = IntShip
    if(p.BestOffer_chbox.isChecked()):
        myitem['Item']['BestOfferDetails'] = {'BestOfferEnabled': 'true'}
    #print(myitem)
    api.execute('VerifyAddItem', myitem)
    print("%s" % api.response.content)
except ConnectionError as e:
    for node in api.response.dom().findall('ErrorCode'):
        print("error code: %s" % node.text)
    if 37 in api.response_codes():
        print("Invalid data in request")
    print(e)
    print(e.response.dict())
好吧没关系......我感到愚蠢......因为我还在沙盒中工作,我正在传递测试照片,其中列表中的某些网址PicURL没有指向有效的照片.
如果其他人得到这些错误,第一种格式是正确的:
"PictureDetails": {"PictureURL": ["http://i.ebayimg.com/picture1",
                                  "http://i.ebayimg.com/picture2"]}
| 归档时间: | 
 | 
| 查看次数: | 520 次 | 
| 最近记录: |