Mailchimp API 3.0批量订阅-Mailchimp3 PY

时间:2018-12-16 09:25:52

标签: python python-3.x mailchimp-api-v3.0

我是Mailchimp api的新手。我有一个具有订户列表的csv文件,该文件需要批量导出到mailchimp。我最初想到在for循环中将每个对象作为json对象进行迭代并进行Apic调用,但这似乎不起作用。然后进一步阅读发现的批处理操作。我正在尝试为每个批次请求设置格式,但出现错误:{“ type”:“ http://developer.mailchimp.com/documentation/mailchimp/guides/error-glossary/”,“ title”:“缺少API密钥”,“状态”:401,“详细信息”:“您的请求不包含API密钥。“,”实例“:” XXX“}

import requests
import csv
import json
import glob
import os
from mailchimp3 import MailChimp



username = 'abc'
apikey = 'xxyyzzz'
url = "https://us12.api.mailchimp.com/3.0/lists/XXXX/members"
headers = {'Content-Type': 'application/json'}
primary_fields = [ 'email_address','status']
result = []
for filename in glob.glob('D:\\abc.csv'):
    csvfile = os.path.splitext(filename)[0]
    jsonfile = csvfile + '.json'

with open('D:\\abc.csv', encoding="ISO-8859-1") as csv_file:
    reader = csv.DictReader(csv_file, skipinitialspace=True)
    for row in reader:
        d = {k: v for k, v in row.items() if k in primary_fields}

        d['merge_fields'] = {k: v for k, v in row.items() if k not in primary_fields}
        result.append(d)  
    with open(jsonfile, 'w')as fp:
        json.dump(result, fp, indent=2)
client = MailChimp(mc_api=apikey, mc_user= username)

with open("D:\\abc.json", "r") as read_file:

    data= json.load(read_file)

       #Create list for dictionaries
    operations = []


    #loop through queryset
    for item in data:

        #Create dictionary for a operation
        operation_item = {"method":"POST", "path":"/lists/XXXX/members/", "body":json.dumps(data)}
        #Append to list
            operations.append(operation_item)
client = MailChimp(mc_api=apikey, mc_user= username)
            batch = client.batches.create(data={"operations": operations})

1 个答案:

答案 0 :(得分:1)

标头中缺少“授权”字段。

headers = {'Content-Type': 'application/json', 'Authorization': 'Basic YOURAPIKEY'}