forked from sunner/buzz2weibo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuzz2weibo.py
executable file
·149 lines (123 loc) · 4 KB
/
buzz2weibo.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
#!/usr/bin/python
# vim: set fileencoding=utf-8 :
# buzz2weibo
# Copyright 2011 Sun Zhigang
# See LICENSE for details.
from config import *
from urllib2 import urlopen, URLError
from json import load
from activity import *
from weibopy.auth import OAuthHandler
from weibopy.api import API
from weibopy.error import WeibopError
from time import sleep
import os, errno, sys
WEIBO_APP_KEY = '3127127763'
WEIBO_APP_SECRET = '21cc35f55fc8fe73b73162964c0bb415'
# 运行一次最多同步几条。缺省3。连续同步太多会被休息的
WEIBO_MAX_SYNC_COUNT = 3
def post2weibo(api, act):
message = act.content + ' ' + act.link
if APPEND_SHARE_FROM_BUZZ_LINK:
message += u' //转发自%s'.encode('utf-8') % act.origin_link
include_image = False
if act.image != '':
# 下载图像文件
try:
u = urlopen(act.image);
data = u.read()
u.close()
except URLError:
# 如果下载不下来,表示……,就别试了,当普通消息发吧
pass
else:
filename = IMAGES_PATH + '/' + act.image_filename
f = open(filename, 'w')
f.write(data)
f.close()
include_image = True
while (True):
try:
if include_image:
api.upload(filename, status=message, lat=act.geo[0], long=act.geo[1])
else:
api.update_status(status=message, lat=act.geo[0], long=act.geo[1])
except WeibopError, e:
if e.reason.find('error_code:400,40013:Error:') == 0:
# 微博太长,剪裁且留原始链接。原始链接不会太长,所以不会死循环
message = unicode(message, 'utf-8')[0:80] + u'....更多:'
message = message.encode('utf-8') + act.origin_link
print '内容过长,截断发表:'
print message
else:
raise
else:
break
return True
# 测试config.py文件是否存在
if not os.path.exists(sys.path[0] + os.sep + 'config.py'):
print '找不到配置文件。请先运行setup.py'
sys.exit(1)
# 建图片目录
try:
os.makedirs(IMAGES_PATH)
except OSError, e:
if e.errno == errno.EEXIST:
pass
else:
raise
buzz_url = 'https://www.googleapis.com/plus/v1/people/' + BUZZ_USERID + '/activities/public?key=' + GOOGLE_API_KEY
# 读buzz
fp = urlopen(buzz_url)
#fp = open('buzz.json')
buzz = load(fp)
fp.close()
# 微博认证
auth = OAuthHandler(WEIBO_APP_KEY, WEIBO_APP_SECRET)
auth.setToken(WEIBO_TOKEN_KEY, WEIBO_TOKEN_SECRET)
api = API(auth)
# 读已经同步过的activity id
synced_ids = set()
try:
fp = open(HISTORY_FILE, 'r')
for line in fp:
synced_ids.add(line.strip())
fp.close()
except IOError, e:
# 如果文件不存在,就继续;否则,触发异常
if e.errno != errno.ENOENT:
raise
# 开始同步
count = 0
items = buzz['items']
items.reverse() # Buzz是后发的在前,所以翻转一下。感谢王瑞珩的建议
for item in items:
act = GooglePlusActivity(item);
# 同步未同步过的
if act.id not in synced_ids:
print '-----------------------'
print 'syncing ' + act.id
print act.origin_link
if act.content != '':
print act.content
if act.link != '':
print act.link
if act.image != '':
print act.image
if act.image_filename != '':
print act.image_filename
if act.geo != '':
print act.geo
if DEBUG:
continue
if post2weibo(api, act):
synced_ids.add(act.id)
# 将同步过的activity id写入历史文件
fp = open(HISTORY_FILE, 'w')
for id in synced_ids:
fp.write(id + '\n')
fp.close()
count = count + 1
if count >= WEIBO_MAX_SYNC_COUNT:
break
sleep(1) # 延时才能让新浪微博按正确顺序显示