일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 파이썬
- 자바
- ansible install
- 도커 시작하기
- mysql on docker
- mysql docker
- elk stack
- 백준
- 정보처리기사
- MySQL
- 도커 elk
- 데이터베이스
- 데이트
- java
- 코딩
- 알고리즘
- 스트림셋이란?
- c
- 스트림셋
- 푸시푸시
- docker
- 앤서블 설치
- 도커
- 클라우드
- C언어
- streamsets 강의
- nvidia docker
- 도커 mysql
- python
- c++
- Today
- Total
리그캣의 개발놀이터
[Python] Facebook Page Crawler 만들기 본문
get_request_url(url)
def get_request_url(url): req = urllib.request.Request(url) try: response = urllib.request.urlopen(req) if response.getcode() == 200: print ("[%s] Url Request Success" %datetime.datetime.now()) return response.read().decode('utf-8') except Exception as e: print(e) print("[%s] Url Error for URL : %s" %(datetime.datetime.now(), url)) return None |
해당 url에 연동 소스코드. get_request_url(url) 을 통하여 json.loads(retData) 의 parameter값을 얻어온다.
이슈) utf-8로 변형 하여야 한다.
getFacebookNumericID(page_id, access_token)
base = "https://graph.facebook.com/v2.8" node = "/" + page_id parameters = "/?access_token=%s" % access_token url = base + node + parameters retData = get_request_url(url) if(retData == None): return None else: jsonData = json.loads(retData) return jsonData['id'] |
FacebookNumericID를 얻어온다. token과 url 정보가 필요.
getFacebookPost(page_id, access_token, from_date, to_date, num_statuses)
def getFacebookPost(page_id, access_token, from_date, to_date, num_statuses): base = "https://graph.facebook.com/v2.8" node = "/%s/posts" % page_id fields = "/?fields=id,message,link,name,type,shares,reactions,"+\ "created_time,comments.limit(0).summary(true)"+\ ".limit(0).summary(true)" duration = "&since=%s&until=%s" % (from_date, to_date) parameters = "&limit=%s&access_token=%s" % (num_statuses,access_token) url = base + node + fields + duration + parameters retData = get_request_url(url) if (retData == None): return None else: return json.loads(retData) |
해당 포스트 정보를 가져와서 retData에 넣어준다.
getPostItem(post,key)
def getPostItem(post,key): try: if key in post.keys(): return post[key] else: return '' except: return '' |
단일 Post Key 값에 해당하는 데이터 반환
getPostTotalCount(post,key)
def getPostTotalCount(post,key): try: if key in post.keys(): return post[key]['summary']['total_count'] else: return 0 except: return 0 |
해당 Post의 키값(reaction, comment등) total_count 반환
getPostData(post, access_token,jsonResult)
def getPostData(post, access_token,jsonResult): post_id = getPostItem(post,'id') post_message = getPostItem(post,'message') post_name = getPostItem(post, 'name') post_link = getPostItem(post,'link') post_type = getPostItem(post,'type') ##### post_num_reactions = getPostTotalCount(post,'reactions') post_num_comment = getPostTotalCount(post,'comments') post_num_shares = 0 if 'shares' not in post.keys() else post['shares']['count'] #페이스북의 시간 형식을 국내 시간형식으로 변환하기 post_created_time = getPostItem(post,'created_time') post_created_time = datetime.datetime.strptime(post_created_time, '%Y-%m-%dT%H:%M:%S+0000') post_created_time = post_created_time + datetime.timedelta(hours=+9) post_created_time = post_created_time.strftime('%Y-%m-%d %H:%M:%S')
reaction = getFacebookReaction(post_id,access_token) if post_created_time > '2016-02-24 00:00:00' else {} post_num_likes = getPostTotalCount(reaction,'like') post_num_likes = post_num_reactions if post_created_time < '2016-02-24 00:00:00' else post_num_likes post_num_loves = getPostTotalCount(reaction, 'love') post_num_wows = getPostTotalCount(reaction,'wow') post_num_hahas = getPostTotalCount(reaction,'haha') post_num_sads = getPostTotalCount(reaction,'sad') post_num_angrys = getPostTotalCount(reaction,'angry') jsonResult.append({'post_id':post_id,'message':post_message, 'name' : post_name, 'link':post_link, 'created_time': post_created_time, 'num_reactions':post_num_reactions, 'num_comments':post_num_comment,'num_shares':post_num_shares, 'num_likes':post_num_likes,'num_loves':post_num_loves, 'num_wows':post_num_wows,'num_hahas':post_num_hahas, 'num_sads':post_num_sads, 'num_angrys':post_num_angrys}) |
페이스북 post 세부내용 얻어오기
getFacebookReaction(post_id, access_token)
def getFacebookReaction(post_id, access_token): base = "https://graph.facebook.com/v2.8" node = "/%s" % post_id reactions = "/?fields="\ "reactions.type(LIKE).limit(0).summary(total_count).as(like)"\ ",reactions.type(LOVE).limit(0).summary(total_count).as(love)"\ ",reactions.type(WOW).limit(0).summary(total_count).as(wow)"\ ",reactions.type(HAHA).limit(0).summary(total_count).as(haha)"\ ",reactions.type(SAD).limit(0).summary(total_count).as(sad)"\ ",reactions.type(ANGRY).limit(0).summary(total_count).as(angry)" parameters = "&access_token=%s" % access_token url = base + node + reactions + parameters retData = get_request_url(url) if(retData == None): return None else: return json.loads(retData) |
페이스북 게시글 ‘좋아요’ 형태 분석하여 retData에 저장
main
def main(): page_name = "jtbcnews" #원하는 pagename 지정 app_id = #본인 app_id 지정 app_secret = #secret 지정 access_token = app_id + "|" + app_secret from_date = '2017-02-01' to_date = '2017-02-03' num_statuses = 10 go_next = True jsonResult = [] page_id = getFacebookNumericID(page_name, access_token) if(page_id == None): print("[%s] %s is Invalid Page Name" % (datetime.datetime.now(), page_name)) exit() print("[%s] %s page id is %s" % (datetime.datetime.now(),page_name,page_id)) jsonPost = getFacebookPost(page_id, access_token,from_date,to_date,num_statuses) if(jsonPost==None): print("No DATA") exit() while(go_next): for post in jsonPost['data']: getPostData(post, access_token,jsonResult) if 'paging' in jsonPost.keys(): jsonPost = json.loads(get_request_url(jsonPost['paging']['next'])) else: go_next = False with open('%s_facebook_%s_%s.json' % (page_name, from_date,to_date), 'w',encoding='utf8') as outfile: str_=json.dumps(jsonResult, indent=4, sort_keys=True, ensure_ascii=False) outfile.write(str_) print("%s_facebook_%s_%s.json SAVED" % (page_name,from_date,to_date)) if __name__ == '__main__': main() |
날짜 선택 및 해당 페이지 이름 지정.
'개발 공부 > Python(웹)' 카테고리의 다른 글
flask와 mysql을 docker container 환경에서 연동해보기 (0) | 2020.08.13 |
---|---|
[Follium] 사용하여 주소를 맵에 표시 (0) | 2018.05.16 |
[pandas] 매장 주소 보정하기. (0) | 2018.05.16 |