굳헬로의 스팀 프로그램 일기!! 쉰세번째 #53 스팀코인판 조합의 자동 보팅시스템 제작 6번째 시간!! 보팅룰 검사 프로그램과 자동 보팅 프로그램의 분리!!

in #sct5 years ago


이제 스팀코인판 원피스 조합의 자동 보팅 프로그램 개발도 거의 막바지에 이르고 있네요.

오늘은 뭔가 생각난 아이디어가 있어서 자동 보팅 프로그램을 업그레이드 해봤는데요.

이제 문제 없이 돌아간다면, 바로 실전에 투입해도 되고, 앞으로 유니온 조합을 비롯하여 새로 생기게 될 조합에도 쉽게 적용을 할 수 있을것 같습니다.

기존에는 자동보팅 프로그램이 새로운 블록을 검사하여 조합원의 포스팅을 찾아내고, 보팅룰에 따라 보팅을 하고 끝이었는데요.

이번에는 블록을 검사하여 조합원의 포스팅을 찾아내는 일과, 보팅을 하는 작업을 분리 하였습니다.

따라서 하나의 프로세스에는 새로운 블록을 검사하여 조합원의 포스팅을 찾아서 데이터베이스에 저장을 하는 작업을 하게 되었고, 다른 프로세스에서는 데이터베이스에 저장된 조합원의 포스팅 정보를 이용해 시간 맞춰 보팅을 수행하게 됩니다.

위와같이 포스트 아이디와, 조합 이름, 스팀 아이디, 홍보글 여부, 보팅룰 등의 정보를 데이터베이스에 저장하여, 앞으로 이 자료를 활용하려고 합니다.

제일 먼저 이 자료를 활용하는 일은 역시나 보팅이 되겠으며, 원하는 시간과 원하는 횟수만큼 보팅할수 있으며, 포스팅 시간과 보팅 시간까지 관리가 가능하게 되었으며, 통계를 웹으로 확인할수 있도록 만들고 있습니다.

먼저 보팅을 하는 코드를 살펴보도록 하겠습니다.

db = pymysql.connect(host=host, port=3306, user=user, passwd=passwd, db=db_name, charset='utf8')
try :
    cursor = db.cursor(pymysql.cursors.DictCursor)
    sql = "SELECT * FROM team1p_vote_db WHERE vote ='n'"
    cursor.execute(sql)
    result = cursor.fetchall()

    for row_data in result:    
        post_id = row_data['post_id']
        today =  row_data['created_time'].strftime("%Y-%m-%d")  
        sql2 = "SELECT * FROM team1p_vote_db WHERE steem_id='" + row_data['steem_id'] + "' && DATE(created_time)='" + today + "'"
        cursor.execute(sql2)
        result2 = cursor.fetchall()
        vote_times = 1

        if len(result2) > vote_times :
            sql3 = "UPDATE team1p_vote_db set vote='p' where post_id='" + post_id + "'"
            cursor.execute(sql3)
            db.commit()
        else :
            userid = "team1p"
            post = Post(row_data['post_id'])
            post_json = post.export()
            vote_check = 0    
            for voter in post_json['active_votes'] :
                if userid == voter['voter'] :
                    vote_check = 1  

            if vote_check == 0 :                                
                after_time = (datetime.datetime.utcnow() - post_json['created']).seconds
                vote_user = Steem(keys=["포스팅키"])              
                
                if after_time >= 300 :                                                           
                    telegram_send = post_id + " 즉시 보팅 완료"
                    bot.sendMessage(chat_id = chat_id, text = telegram_send)                            
                    vote_user.commit.vote(post_id , int(row_data['vp']), "team1p")     
                elif after_time < 300 :
                    time.sleep(300 - after_time)                                                        
                    telegram_send = post_id + " 5분 보팅 완료"
                    bot.sendMessage(chat_id = chat_id, text = telegram_send) 
                    vote_user.commit.vote(post_id , int(row_data['vp']), "team1p")  

                sql4 = "UPDATE team1p_vote_db set vote='y' where post_id='" + post_id + "'"
                cursor.execute(sql4)
                db.commit()

except Exception as e:
    print('오류발생 : ' + str(e))         

db.close()

블록을 검사하는 프로그램이 데이터베이스에 조합원의 새글 정보를 등록하면, 해당일자에 포스팅 개수를 검사하고, 조합에서 설정한 vote_times 만큼 보팅을 수행할 수 있습니다.

그리고 보팅 작업 완료 여부를 저장하게 되며, 텔레그램으로 알림을 받는 코드까지 완성이 되었네요.

현재 보팅 현황을 확인하는 웹 페이지를 만들고 있는데, 내일까지는 완성이 될 것 같네요.

현재 조합원의 글이 올라오면 텔레그램으로 알림이 오고

데이터베이스에 정보를 기록하고 있습니다.

현재 테스트중이라 보팅 타임까진 체크를 완료하진 못했는데, 이 작업은 수정이 좀 필요할 것 같습니다.

어쨋든 추석이 끝나고 나서야 실전에 투입가능할 줄 알았는데, 지금 당장 조합의 자동 보팅 프로그램으로투입해도 사용하는데는 불편함이 없을것 같네요.

하지만 마무리가 중요하겠죠.

빠르면 내일, 늦어도 수요일까지는 모든 작업을 마무리 하고, 빨리 스팀몬스터 자동화 프로그램 개발에 착수하고 싶네요.

그럼 여러분들 오늘 하루도 파이팅하시고, 행복한 하루 행복한 한주 보내시길 바랍니다.


굳헬로의 스팀 프로그램 일기!! 시리즈

#1 Python 프로그램 설치 && steemengine 파이썬 api 설치 && 간단한 steemengine 예제

#2 비주얼 스튜디오 코드 프로그램 설치 && 비주얼 스튜디오 코드를 사용하여 파이썬 다루기 && 간단한 steemengine 예제

#3 스팀엔진 토큰의 정보를 가져오는 findOne() && 누군가의 토큰 사용 내역을 가져오는 get_history() && JSON 데이터 출력

#4 steemengine Token 클래스 && Token.get_holder() && Token.get_market_info() && Token.get_buy_book() && Token.get_sell_book()

#5 스팀엔진 블록을 뒤져서 원하는 정보를 찾아보자!! 스팀엔진 마켓 거래 내역을 뽑아내는 예제

#6 파이썬으로 스팀엔진 토큰들을 클레임 해보자.

#7 드디어 첫 실전!! 무한 반복 작업 수행하기!! 이제 직접 클레임 하는 손맛은 잊자. 무한 반복 자동 클레임!!

#8 텔레그램 봇을 이용해 알림을 받아보자!! && 무한 반복 자동 클레임의 정보를 텔레그램으로 받아보기!!

#9 무한 반복 자동 클레임 업그레이드!! && 토큰 잔고 확인 && 토큰 전송과 토큰 전송 내역을 텔레그램으로 받아보기!!

#10 토큰 전송내역을 검사하고, 토큰을 전송 받으면 텔레그램으로 알림을 받아보기!!

#11 스팀엔진 토큰 임대내역 추적. 쉽지 않았던 머나먼 여정 (1/2)

#12 스팀엔진 토큰 임대내역 추적. 쉽지 않았던 머나먼 여정 (2/2) 스팀엔진 토큰 임대내역 추적 완료!!

#13 웹 프로그래밍의 시작!! 파이썬을 이용하여 정보를 MySQL 데이터 베이스에 저장해보기!!

#14 파이썬을 이용하여 데이터베이스로부터 정보를 가져오기 && 스팀코인판 3대풀 임대내역 데이터베이스 작업 완료!!

#15 웹 프로그래밍을 이용하여 스팀코인판 3대조합의 임대 내역을 웹으로 확인해보자 !!

#16 스팀엔진 최신 블록을 검사하여 필요한 정보를 데이터베이스에 저장하기!! 3대 조합의 임대내역을 최신으로 저장하기!!

#17 조합들이 필요한 기능 드디어 완성!! 자동 클레임과 자동 분배 기능!!

#18 스팀코인판 3대 조합의 임대내역과 실시간 예상 분배 금액을 웹으로 확인해보자!!

#19 어제 만든 프로그램 업그레이드!! 개별 상세내역보기 기능 추가!!

#20 시행착오... 그리고 시련... 하지만 원사마님 덕분으로 엄청난 레벨업!! 감사합니다. 더욱 발전하겠습니다.

#21 레벨업을 했지만 또 다시 찾아온 시련!! 프로그램 결과와 블록체인에 기록된 결과가 다르다!! 어떻게 해야 할까...

#22 오늘부터 새로운 도전!! 자동 보팅 만들기!! 그 첫번째 스팀코인판의 소각글에 자동보팅을 해보자!! 첫번째 시간 (1/N)

#23 스팀코인판의 소각글의 정보를 가지고 와서 자동보팅을 해보자!! 그 두번째 시간 (2/N)

#24 스팀코인판 3대조합의 임대내역을 웹으로 확인해보자!! 업그레이드!!

#25 스팀코인판 3대조합의 임대내역을 웹으로 확인해보자!! 업그레이드 2!! 그리고 개발 예정 사항 공개!!

#26 드디어 첫 실전 가동 준비중... 스팀코인판 유니온 조합의 수익 자동분배 작업 완료중...

#27 스팀코인판 유니온 조합 첫 자동 분배 결과!! 그리고 보완!!

#28 스팀코인판 유니온 조합 자동 분배 프로그램의 결과를 웹으로 확인해 보자!!

#29 스팀코인판 유니온 조합 자동 분배 상황을 텔레그램으로 확인!! 임내 확인 페이지 정렬 기능 추가!!

#30 스팀코인판 조합의 임대량 페이지 정렬 기능 업그레이드!! 그리고 임대량 파이 차트 완성!!

#31 스팀코인판 조합의 하루하루 임대량 변화를 차트로 확인해보자!!

#32 트리플A를 이용하면서 그동안 번거로웠던 클레임 스테이킹 전송 작업 이젠 안녕!! 자동으로 AAA를 전송하고 클레임하고 스테이킹을 해보자!!

#33 굳헬로가 만든 스팀코인판 조합 자동 클레임과 자동 분배 프로그램 원피스 조합에도 사용 개시!!

#34 스팀코인판 조합 원피스 자동 클레임과 자동 분배 프로그램 업그레이드!! 텔레그램 봇으로 그룹 메시지를 받아보자!!

#35 스팀에서 새글 정보를 텔레그램으로 받아보자!! 함께 정보를 받아보는 텔레그램 그룹방 개설!!

#36 스팀엔진 블록 검사 놓치는 블록이 없도록 해보자!! 파일 입출력 기능 활용!!

#37 스팀엔진 블록을 검사하여 본인글의 댓글을 텔레그램 알람으로 받아보자!!

#38 드디어 완성!! 보팅 알람봇!! 스팀엔진 블록을 검사하여 본인글에 보팅이 찍히면 텔레그램 알람으로 받아보자!!

#39 파이썬과 텔레그램을 이용한 챗봇 프로그래밍의 시작!! 그 첫번째!! 챗봇과 대화를 해보고,특정 메시지에 반응을 해보자!!

#40 파이썬과 텔레그램을 이용한 챗봇 프로그래밍!! 파이썬에 CommandHandler를 사용하여 특정 명령어를 내려보자!!

#41 굳헬로의 텔레그램 보팅알람 서비스 일단은 완성!! 앞으로 다양한 기능 추가 예정!! 사용해보고 후기 남겨주세요!!

#42 업비트의 원화 마켓 코인들의 시세를 텔레그램으로 받아보자!! /get 비트코인, /get 스팀, /get 코인이름 명령어 등록!!

#43 업비트의 원화 마켓 코인들의 시세를 텔레그램으로 받아보자2!! 알려줘 비트코인, 알려줘 스팀 노노!! 이제 바로 비트코인 스팀 명령어 등록!!

#44 매일 매일 새로운 기능이 추가되고 있는 굳스팀 챗봇!! 챗봇을 이용하여 스팀엔진 토큰의 시세 정보를 받아보자!!

#45 텔레그램 챗봇을 이용하여 최신 코인 주요 뉴스를 받아보자!! 굳스팀 챗봇 소개!!

#46 굳스팀 텔레그램 챗봇 새 기능 추가!! 굳스팀 챗봇을 이용하여 최신 헤드라인 뉴스 정보를 받아보자!!

#47 뉴스를 구독해보자!! 명령어 입력없이 특정 시간 챗 봇이 뉴스를 자동으로 보내 드립니다.

#48 본격적으로 스팀코인판 조합의 자동 보팅시스템 제작 돌입!! 기본 설계 및 보팅 설정 페이지 작업 완료!!

#49 스팀코인판 조합의 자동 보팅시스템 제작 2번째 시간!! 보팅 설정에 따라 각 조합원 별로 보팅룰을 적용해 보자!!

#50 스팀코인판 조합의 자동 보팅시스템 제작 3번째 시간!! 설 정된 보팅룰을 파이썬 자동 보팅 프로그램에 가져오기!!

#51 스팀코인판 조합의 자동 보팅시스템 제작 4번째 시간!! 블록을 검사하여 설정된 보팅룰로 보팅하기!!

#52 스팀코인판 조합의 자동 보팅시스템 제작 5번째 시간!! 자동 보팅시스템 테스트 현황!! 굳!! 따봉~~

Sort:  

jcar토큰 9월 구독 보팅입니다.
날마다 좋은 하루 되세요.

Thank you for your continued support towards JJM. For each 1000 JJM you are holding, you can get an additional 1% of upvote. 10,000JJM would give you a 11% daily voting from the 700K SP virus707 account.

Hi @goodhello!

Your post was upvoted by @steem-ua, new Steem dApp, using UserAuthority for algorithmic post curation!
Your UA account score is currently 4.012 which ranks you at #3993 across all Steem accounts.
Your rank has not changed in the last three days.

In our last Algorithmic Curation Round, consisting of 69 contributions, your post is ranked at #23.

Evaluation of your UA score:
  • Some people are already following you, keep going!
  • The readers like your work!
  • Try to work on user engagement: the more people that interact with you via the comments, the higher your UA score!

Feel free to join our @steem-ua Discord server

Coin Marketplace

STEEM 0.30
TRX 0.11
JST 0.033
BTC 63968.82
ETH 3136.80
USDT 1.00
SBD 4.28