2013-08-27 47 views
0

我在尝试上传照片到Facebook页面的脚本时遇到了一些麻烦。只有通过字符串时,它才能正常工作。页面文章需要源文件(图片),这是我遇到的问题。这将返回一个400错误。发送文件python

我不完全知道如何处理图像(和我们的目标是做这个是大头,所以我非常喜欢图像的压缩文件。)

这里是相当于卷曲请求正常工作: 卷曲-F '=消息簿号码://bit.ly/alaska' -F '[email protected]' -F '出版= 0' -F '=的access_token TEST' https://graph.facebook.com/act_id/photos

import os 
import requests 
import csv 
import time 
import thread 
import zipfile 
from datetime import datetime 
from json import JSONEncoder 
from flask import Flask, request, redirect, url_for, send_from_directory, \ 
        render_template 
from flask.ext.mail import Mail, Message 
from werkzeug import secure_filename 


email = '' 
token='' 
pageid = '' 
filename = 'test.csv' 
images = 'test.zip' 
from flask import request 

raw_input = open(filename, 'rb') 
info = csv.DictReader(raw_input) 
imagefile = zipfile.ZipFile(images, mode='r')   
creation_date = datetime.now().strftime('%m-%d-%Y') 
output_csv_name = \ 
    "unpublished_posts_%s_%s.csv" % (pageid, creation_date) 
output_csv = open(output_csv_name, 'wb') 
writer = csv.writer(output_csv, quoting=csv.QUOTE_NONNUMERIC) 
writer.writerow(('message', 
    'source', 
    'published', 
    'scheduled_publish_time', 
    'genders', 
    'age_max', 
    'age_min', 
    'countries', 
    'regions', 
    'cities', 
    'relationship_statuses', 
    'interested_in', 
    'locales', 
    'education_statuses', 
    'work_networks', 
    'college_networks', 
    'college_majors', 
    'college_years', 
    'post_id' 
    )) 

posts = [] 
targeting_params = ['genders', 
    'age_max', 
    'age_min', 
    'countries', 
    'regions', 
    'cities', 
    'relationship_statuses', 
    'interested_in', 
    'locales', 
    'education_statuses', 
    'work_networks', 
    'college_networks', 
    'college_majors', 
    'college_years'] 

for idx, row in enumerate(list(info)): 
    # convert date string to unix time-stamp 
    if row['scheduled_publish_time'] <> '': 
     s = row['scheduled_publish_time'] 
     timestamp = \ 
        time.mktime(datetime.strptime(s, "%d/%m/%Y").timetuple()) 
       row['scheduled_publish_time'] = timestamp 

    post_params = [s for s in row.keys() if s not in targeting_params] 
    post_params.append('targeting') 

    for param in targeting_params: 
     if len(row[param]) > 0: 
      row[param] = row[param].split(",") 

    targeting_dict = {k: row[k] for k in targeting_params} 
    targeting_dict = dict([(k, v) for k, v in targeting_dict.items() \ 
            if len(v) > 0]) 
    row['targeting'] = JSONEncoder().encode(targeting_dict) 

    row = {k: row[k] for k in post_params} 
    row = dict([(k, v) for k, v in row.items() if len(v) > 0]) 

    message = row['message'] 
    row[u'message'] = u''.join(unichr(ord(c)) for c in row['message']) 

    imagename = row[u'source'] 
    imagedata = imagefile.extract(imagename) 
    files = {'source': open(imagedata, 'rb')} 
    api_method = 'https://graph.facebook.com/%s/feed?access_token=%s' 
    response = requests.post(api_method % (pageid, token),params=row,files=files) 

对不起,如果不够清楚。不知道什么是相关的,什么不相关。我之前工作的脚本中所做的所有更改都是在请求中添加了“文件”,所以我很确定这是我犯了错误的地方。

谢谢!

回答

1

试试这个:

files = { 'source': imagedata }

基本上就无法打开()imagedata这已经是一个字符串(开放()仅适用于文件),所以你只要提交原样和要求将负责多部分编码。

另请参阅this关于使用请求进行文件上传的问题。

+0

您可以使用[StringIO](http://docs.python.org/2/library/stringio.html)打开一个字符串作为文件。 – korylprince