一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - 用Python的Django框架編寫從Google Adsense中獲得報表的應用

用Python的Django框架編寫從Google Adsense中獲得報表的應用

2020-06-08 10:10腳本之家 Python

這篇文章主要介紹了用Python的Django框架編寫從Google Adsense中獲得報表的應用,主要利用了官方的Google Adsense API,需要的朋友可以參考下

 我完成了更新我們在 Neutron的實時收入統計。在我花了一周的時間完成并且更新了我們的PHP腳本之后,我最終認決定開始使用Python進行抓取,這是值得我去花費我的時間和精力的事情。我建立了一個 Django程序,它可以從不同的來源存儲收入統計,我可以用這些去簡歷視圖和用于統計工具的API。

所以在過去的幾天里,我寫了一個腳本,它可以登入到其他的網頁并抓取數據,或者,如果這些網頁有 API,可以直接訪問 API。我發現了一些事情。

1.requests >httplib2(requests多于httplib2);

2.SOAP很糟糕,但它至少是一個API,Suds使SOAP好一點。我了解到SOAP是我說知道的API中,唯一一個完全基于.net開發的。

3.Beautiful Soup是一個很好的求助對象;

4.我確實十分驚訝,這么多企業能在如此蹩腳的技術中生存下來。
 

我拯救了 Google Adsense,他們將會擁有最好的API,并且因此成為最簡單的實現。他有著比我預想的要多的挑戰。顯然你無法僅僅插入用戶名/密碼或是APIkey去獲取獲得進入API的入口,你必須完成整個Oauth2的握手流程。

不幸的是,我發現文檔不如我希望過得那樣容易查詢。我發現了很多死鏈接。我認為,在這方面Google的人應該做的更好。例如,在他們的up to date developer docs文檔中,我發現他們指出了broken link to read more about authentication and authorization。(好的,多么奇怪,我盡快提交了這個問題,這個鏈接終于開始工作了,我猜你會感謝我。)


所以,這篇博客將嘗試記錄從Adsense獲取報表到我的Django應用的過程。

為了使用Google的API來訪問Adsense報表,你需要使用Adsense Management API. 這個API只提供OAuth,所以你需要在瀏覽器中至少完成一次認證過程,來獲取你的證書,然后你可以保存這些證書來進行下一步操作。說實話,我已經聽說過OAuth很多次了,但是直到現在,我在實踐中仍沒有需要來使用它。所以我是邊做邊學,并歡迎大家留言指出我說的不對的地方。

就我所知,Google對于它的各種產品都擁有一個龐大的API。在研究Adsense之前,你需要在Google API 控制臺注冊你的應用。我已經成功注冊了我的應用。因為我還沒有一個可用的URL地址,我現在暫時使用我的開發URL(localhost:8000)。它運作起來似乎正常。并使用提供的這個鏈接下載JSON文件。

還有,當你管理你的APIs的時候,你需要打開服務選項卡,打開AdSense Management API選項。否則,當你嘗試發送請求的時候,你會得到一個錯誤消息“Access Not Configured”。


Google已經創建了一個Python 客戶端庫,你可以輕易的通過pip來安裝這個庫。它還包含一個Django樣例項目,這個項目使用這個庫實現OAuth2的握手過程。我想,它是使用Django 1.1編寫的(因為在寫這個項目的時候,Django 1.5才剛剛發布),所以它可能有點過時,但是它可是一個好的開始點。

我的應用很簡單。我只需要讀取指定日期的收益金額,并保存到我的本地數據庫。

我在djaongo項目中創建了一個新的應用,叫做“adsense”。并創建了一個models.py文件來存儲認證證書。
 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
from django.contrib.auth.models import User
from django.db import models
from oauth2client.django_orm import CredentialsField
 
class Credential(models.Model):
  id = models.ForeignKey(User, primary_key=True)
  credential = CredentialsField()
 
class Revenue(models.Model):
  date = models.DateField(unique=True)
  revenue = models.DecimalField(max_digits=7, decimal_places=2)
 
  def __unicode__(self):
    return '{0} ${1}'.format(self.date, self.revenue)


我把從API控制臺下載的JSON文件放到我的應用的文件夾下面,并創建了一個views.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
import os
 
from django.conf import settings
from django.contrib.auth.decorators import login_required
from django.contrib.sites.models import Site
from django.http import HttpResponseBadRequest, HttpResponse
from django.http import HttpResponseRedirect
from oauth2client import xsrfutil
from oauth2client.client import flow_from_clientsecrets
from oauth2client.django_orm import Storage
 
from .models import Credential
 
CLIENT_SECRETS = os.path.join(os.path.dirname(__file__), 'client_secrets.json')
 
FLOW = flow_from_clientsecrets(
  CLIENT_SECRETS,
  scope='https://www.googleapis.com/auth/adsense.readonly',
  redirect_uri='http://{0}/adsense/oauth2callback/'.format(
    Site.objects.get_current().domain))
 
@login_required
def index(request):
  storage = Storage(Credential, 'id', request.user, 'credential')
  credential = storage.get()
  if credential is None or credential.invalid is True:
    FLOW.params['state'] = xsrfutil.generate_token(settings.SECRET_KEY,
                            request.user)
    authorize_url = FLOW.step1_get_authorize_url()
    return HttpResponseRedirect(authorize_url)
  else:
    return HttpResponse('Already validated.')
 
@login_required
def auth_return(request):
  if not xsrfutil.validate_token(settings.SECRET_KEY,
                  request.REQUEST['state'], request.user):
    return HttpResponseBadRequest()
  credential = FLOW.step2_exchange(request.REQUEST)
  storage = Storage(Credential, 'id', request.user, 'credential')
  storage.put(credential)
  return HttpResponseRedirect("/")

在 urls.py 文件中我包含了一個鏈接指向我的應用的url文件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
main urls.py:
 
from django.conf.urls import patterns, include, url
from django.contrib import admin
 
admin.autodiscover()
 
urlpatterns = patterns(
  '',
  url(r'^adsense/', include('adsense.urls', namespace='adsense')),
 
  url(r'^admin/doc/', include('django.contrib.admindocs.urls')),
  url(r'^admin/', include(admin.site.urls)),
)
 
adsense/urls.py:
 
from django.conf.urls import patterns, url
 
urlpatterns = patterns(
  'adsense.views',
  url(r'^$', 'index', name='index'),
  url(r'^oauth2callback/$', 'auth_return', name='auth_return'),
)

最后,創建了一個通過給定日期調用API并獲取收益的類。它放在adsense/tasks.py,因為我準備把它當作任務,鉤在 Celery/ RabbitMQ之上。
 

?
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
import datetime
import httplib2
 
from apiclient.discovery import build
from django.contrib.auth.models import User
from oauth2client.django_orm import Storage
 
from .models import Credential, Revenue
 
TODAY = datetime.date.today()
YESTERDAY = TODAY - datetime.timedelta(days=1)
 
class Scraper(object):
  def get_report(self, start_date=YESTERDAY, end_date=TODAY):
    user = User.objects.get(pk=1)
    storage = Storage(Credential, 'id', user, 'credential')
    credential = storage.get()
    if not credential is None or credential.invalid is False:
      http = httplib2.Http()
      http = credential.authorize(http)
      service = build('adsense', 'v1.2', http=http)
      reports = service.reports()
      report = reports.generate(
        startDate=start_date.strftime('%Y-%m-%d'),
        endDate=end_date.strftime('%Y-%m-%d'),
        dimension='DATE',
        metric='EARNINGS',
      )
      data = report.execute()
      for row in data['rows']:
        date = row[0]
        revenue = row[1]
 
        record = Revenue()
        try:
          r = Revenue.objects.get(date=date)
          pk = r.id
        except Revenue.DoesNotExist:
          pk = None
        record.id = pk
        record.date = date
        record.revenue = revenue
        record.save()

為了讓它能工作起來,我在瀏覽器打開http://localhost:8000/adsense/。這時候會要求我登錄Google帳號。我為我的應用授權來訪問Adsense。然后,認證證書就會保存在我的本地數據庫,然后我可以調用Scraper get_report() 方法。祝賀我吧!。它能順利工作了。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: spy2wc48美女撒尿 | 欧美一卡2卡3卡四卡海外精品 | 色噜噜 男人的天堂在线观看 | 奇米小说 | 欧美日韩一二三区免费视频观看 | 三级网站午夜三级 | 四虎影院网址大全 | 男人晚上看的 | 无限资源在线观看完整版免费下载 | 17岁韩国在线观看免费1 | julia ann黑人巨大 | 高清一区二区 | 男人吃奶动态图 | 天天色踪合 | 青草欧美 | 成年人免费在线看 | 亚洲精品老司机福利在线播放 | 欧美国产在线视频 | 我和岳偷长篇小说 | 日本中文字幕高清 | 欧美视频在线一区 | 久久国产精品免费网站 | 国产精品免费久久久久影院小说 | 国产一区二区三区高清视频 | 国产资源在线视频 | 国产成人在线视频播放 | 亚洲另类老妇videos | 操人网 | 亚洲国产精品自在自线观看 | 国产成人综合亚洲一区 | 免费日批视频 | 激情小说色图 | 激情综合| 亚洲精品精品一区 | 日韩香蕉网| 国产成人福利免费视频 | gayrb漫画免费入口 | 国产伦码精品一区二区三区 | 欧美一区二区三区四区视频 | 亚洲mm色国产网站 | 国产最强大片免费视频 |