利用Python進行數據分析 - 引言のusa.gov數據示例

概述

該系列是關于《利用Python進行數據分析》的學習筆記,對應 引言 > 來自bit.ly的1.usa.gov數據 部分。

來自bit.ly的1.usa.gov數據

注意:該部分使用了《利用Python進行數據分析》的數據,可以去pydata-book - github下載數據。另外,使用Spyder進行該次實驗,記得將文件目錄設置為對應的pydata-book

下列代碼用來載入數據,了解數據格式:

# 數據集對應路徑
path = 'ch02/usagov_bitly_data2012-03-16-1331923249.txt'
# 顯示數據集的第一行
open(path).readline()
# 此處應該可以看到一長串字符串,為JSON格式

下列代碼使用Python中內置的JSON庫,將上述JSON格式的字符串轉化為Python的字典對象:

import json
path = 'ch02/usagov_bitly_data2012-03-16-1331923249.txt'
records = [json.loads(line) for line in open(path)]  # 轉化為Python的字典對象
records[0]  # 檢查第一條記錄

對時區進行計數(純Python代碼)

該部分用來對上述數據集中的時區字段(tz字段)進行計數。

# 導入數據,并轉化為Python字典對象

# 下列代碼會報錯,因為并不是所有記錄都有'tz'這個字段
# time_zones = [rec['tz'] for rec in records]

time_zones = [rec['tz'] for rec in records if 'tz' in rec]
# 檢查數據集中時區字段的前十個
time_zones[:10]

之后再使用純Python代碼對time_zones進行計數,思路是遍歷字典慢慢數

def get_counts(sequence):
    counts = {}
    for x in sequence:
        if x in counts:
            counts[x] += 1
        else:
            counts[x] = 1
    return counts

或者,使用Python的標準庫defaultdict :

from collections import defaultdict

def get_counts(sequence):
    counts = defaultdict(int)  # 所有的值均會被初始化為0
    for x in sequence:
        counts[x] += 1
    return counts

注意defaultdict的特性可以參見The Python Standard Library。簡單來說,就是會用特定類型的默認值初始化第一次出現的鍵。

之后,進行測試:

counts = get_counts(time_zones)
counts['America/New_York']  # 檢查New York這個時區的計數情況

如果想得到時區計數的前十名及對應的時區,可以使用如下代碼:

def top_counts(count_dict, n=10):
    value_key_pairs = [(count, tz) for tz, count in count_dict.items()]
    value_key_pairs.sort()
    return value_key_pairs[-n:]

top_counts(counts)

當然,你也可以使用Python標準庫collections.Counter來完成上述任務:

from collections import Counter
counts = Counter(time_zones)  # 計數
counts.most_common(10)  # 計數前十

注意,可以參見The Python Standard Library了解更多關于Counter的細節。

使用pandas對時區進行計數

實現對時區的計數,只需要如下代碼:

from pandas import DataFrame, Series
import pandas as ps
import numpy as np

frame = DataFrame(records)
print frame  # 檢視frame,一長串。這被稱為frame的摘要視圖(summary view)

# frame['tz']返回的為Series對象
# Series對象的value_counts方法會對其進行計數
tz_counts = frame['tz'].value_counts()

下面我們用這段數據生成一張圖片:

clean_tz = frame['tz'].fillna('Missing')  # 用`Missing`替換缺失值
clean_tz[clean_tz == ''] = 'Unknown'  # 用`Unknown`替換空白值

tz_counts = clean_tz.value_counts()
print tz_counts[:10]  # 檢視計數的前十項
tz_counts[:10].plot(kind='barh', rot=0)  # 繪圖,可視化的方式展示前十項
tz_counts.png

注意,Spyder中更改下設置,可以避免每次都要手動引入NumPy及Matploylib。具體來說,將Spyder > Tools > Preferences > IPython console > Graphics中Support for graphicsAutomatically load Pylab and NumPy modules勾選上。

為熟悉pandas,我們再來看看字段a,該字段含有執行URL短縮操作的瀏覽器、設備、應用程序的相關信息:

frame['a'][1]
# u'GoogleMaps/RochesterNY'
frame['a'][59]
# u'Mozilla/5.0 (iPhone; CPU iPhone OS 5_1 like Mac OS X) AppleWebKit/534.46 (KHTML, like Gecko) Mobile/9B176'

我們現在來統計按Windows和非Windows用戶對時區統計信息進行分解,為簡單起見,我們假定字段a中含有"Windows"就認為該用戶為Windows用戶,反之就認為為非Windows用戶。

cframe = frame[frame.a.notnull()]  # 剔除字段`a`為空的數據
# 根據字段`a`分為Windows用戶和非Windows用戶
operating_system = np.where(cframe['a'].str.contains('Windows'),
                                              'Windows', 'Not Windows')
# 根據時區和操作系統信息進行分組
by_tz_os = cframe.groupby(['tz', operating_system])
# size對分組結果進行計數
# unstack對計數結果進行重塑
agg_counts = by_sz_os.size().unstack().fillna(0)

最后,我們來選取最常出現的時區:

# 用于按升序排列
indexer = agg_counts.sum(1).argsort()
count_subset = agg_counts.take(indexer)[-10:]
# 生成一張堆積條形圖
count_subset.plot(kind='barh', stacked=True)

# 生成對應的比例圖
normed_subset = count_subset.div(count_subset.sum(1), axis=0)
normed_subset.plot(kind='barh', stacked=True)
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,362評論 6 537
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,013評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,346評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,421評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,146評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,534評論 1 325
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,585評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,767評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,318評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,074評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,258評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,828評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,486評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,916評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,156評論 1 290
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,993評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,234評論 2 375

推薦閱讀更多精彩內容