A. 做大數據分析一般用什麼工具呢
java :只要了解一些基礎即可,做大數據不需要很深的Java 技術,學java SE 就相當於有學習大數據。基礎
Linux:因為大數據相關軟體都是在Linux上運行的,所以Linux要學習的扎實一些,學好Linux對你快速掌握大數據相關技術會有很大的幫助,能讓你更好的理解hadoop、hive、hbase、spark等大數據軟體的運行環境和網路環境配置,能少踩很多坑,學會shell就能看懂腳本這樣能更容易理解和配置大數據集群。還能讓你對以後新出的大數據技術學習起來更快。
好說完基礎了,再說說還需要學習哪些大數據技術,可以按我寫的順序學下去。
Hadoop:這是現在流行的大數據處理平台幾乎已經成為大數據的代名詞,所以這個是必學的。Hadoop裡麵包括幾個組件HDFS、MapRece和YARN,HDFS是存儲數據的地方就像我們電腦的硬碟一樣文件都存儲在這個上面,MapRece是對數據進行處理計算的,它有個特點就是不管多大的數據只要給它時間它就能把數據跑完,但是時間可能不是很快所以它叫數據的批處理。
記住學到這里可以作為你學大數據的一個節點。
Zookeeper:這是個萬金油,安裝Hadoop的HA的時候就會用到它,以後的Hbase也會用到它。它一般用來存放一些相互協作的信息,這些信息比較小一般不會超過1M,都是使用它的軟體對它有依賴,對於我們個人來講只需要把它安裝正確,讓它正常的run起來就可以了。
Mysql:我們學習完大數據的處理了,接下來學習學習小數據的處理工具mysql資料庫,因為一會裝hive的時候要用到,mysql需要掌握到什麼層度那?你能在Linux上把它安裝好,運行起來,會配置簡單的許可權,修改root的密碼,創建資料庫。這里主要的是學習SQL的語法,因為hive的語法和這個非常相似。
Sqoop:這個是用於把Mysql里的數據導入到Hadoop里的。當然你也可以不用這個,直接把Mysql數據表導出成文件再放到HDFS上也是一樣的,當然生產環境中使用要注意Mysql的壓力。
Hive:這個東西對於會SQL語法的來說就是神器,它能讓你處理大數據變的很簡單,不會再費勁的編寫MapRece程序。有的人說Pig那?它和Pig差不多掌握一個就可以了。
Oozie:既然學會Hive了,我相信你一定需要這個東西,它可以幫你管理你的Hive或者MapRece、Spark腳本,還能檢查你的程序是否執行正確,出錯了給你發報警並能幫你重試程序,最重要的是還能幫你配置任務的依賴關系。我相信你一定會喜歡上它的,不然你看著那一大堆腳本,和密密麻麻的crond是不是有種想屎的感覺。
Hbase:這是Hadoop生態體系中的NOSQL資料庫,他的數據是按照key和value的形式存儲的並且key是唯一的,所以它能用來做數據的排重,它與MYSQL相比能存儲的數據量大很多。所以他常被用於大數據處理完成之後的存儲目的地。
Kafka:這是個比較好用的隊列工具,隊列是干嗎的?排隊買票你知道不?數據多了同樣也需要排隊處理,這樣與你協作的其它同學不會叫起來,你干嗎給我這么多的數據(比如好幾百G的文件)我怎麼處理得過來,你別怪他因為他不是搞大數據的,你可以跟他講我把數據放在隊列里你使用的時候一個個拿,這樣他就不在抱怨了馬上灰流流的去優化他的程序去了,因為處理不過來就是他的事情。而不是你給的問題。當然我們也可以利用這個工具來做線上實時數據的入庫或入HDFS,這時你可以與一個叫Flume的工具配合使用,它是專門用來提供對數據進行簡單處理,並寫到各種數據接受方(比如Kafka)的。
Spark:它是用來彌補基於MapRece處理數據速度上的缺點,它的特點是把數據裝載到內存中計算而不是去讀慢的要死進化還特別慢的硬碟。特別適合做迭代運算,所以演算法流們特別稀飯它。它是用scala編寫的。Java語言或者Scala都可以操作它,因為它們都是用JVM的。
B. python數據分析需要學習哪些內容
1.統計基礎
理工科的學生在本科階段學習過概率論與數理統計,單從做數據分析的角度已經夠用。其他方面,可以根據需要查看相關書籍,隨時進行查漏補缺即可。個人推薦《深入淺出統計學》,可以讓統計理論的學習有趣又自然。
2.資料庫知識
關系型資料庫很重要。在學習數據分析的初期甚至很長一段時間,你接觸到的數據都存儲在關系型資料庫中,需要學習SQL語言進行數據查詢。關於SQL語言,強力推薦《SQL必知必會》,整本書通俗易懂,是學習SQL語言的不二之選。
學習資料庫的本質就是在學習一種與數據打交道的邏輯思維與能力。編程中的很多思想都和關系型資料庫、SQL相通,比如:SQL中對data進行group by的操作,這個在Excel里類似於透視表,在Python/R中也有相應的group function去處理數據。甚至在以後的進階過程,你會接觸到分布式資料庫和所對應的no-SQL語句。
3.編程能力
Excel。 透視表(Pivot Table)是做數據分析的必備技能。透視表可以幫你迅速匯總數據,看到各類型數據的直觀特徵就像是讓你站在更高的視角看待數據。作為進階,Excel自帶的函數、各種插件,以及VBA也是很好的工具。
C. 大數據分析一般用什麼工具呢
雖然數據分析的工具千萬種,綜合起來萬變不離其宗。無非是數據獲取、數據存儲、數據管理、數據計算、數據分析、數據展示等幾個方面。而SAS、R、SPSS、python、excel是被提到頻率最高的數據分析工具。
Python
Python,是一種面向對象、解釋型計算機程序設計語言。Python語法簡潔而清晰,具有豐富和強大的類庫。它常被昵稱為膠水語言,能夠把用其他語言製作的各種模塊(尤其是C/C++)很輕松地聯結在一起。
常見的一種應用情形是,使用Python快速生成程序的原型(有時甚至是程序的最終界面),然後對其中有特別要求的部分,用更合適的語言改寫,比如3D游戲中的圖形渲染模塊,性能要求特別高,就可以用C/C++重寫,而後封裝為Python可以調用的擴展類庫。需要注意的是在您使用擴展類庫時可能需要考慮平台問題,某些可能不提供跨平台的實現。
R軟體
R是一套完整的數據處理、計算和制圖軟體系統。它可以提供一些集成的統計工具,但更大量的是它提供各種數學計算、統計計算的函數,從而使使用者能靈活機動的進行數據分析,甚至創造出符合需要的新的統計計算方法。
SPSS
SPSS是世界上最早的統計分析軟體,具有完整的數據輸入、編輯、統計分析、報表、圖形製作等功能,能夠讀取及輸出多種格式的文件。
Excel
可以進行各種數據的處理、統計分析和輔助決策操作,廣泛地應用於管理、統計財經、金融等眾多領域。
SAS軟體
SAS把數據存取、管理、分析和展現有機地融為一體。提供了從基本統計數的計算到各種試驗設計的方差分析,相關回歸分析以及多變數分析的多種統計分析過程,幾乎囊括了所有最新分析方法,其分析技術先進,可靠。分析方法的實現通過過程調用完成。許多過程同時提供了多種演算法和選項。
D. 利用python實現數據分析
鏈接:
煉數成金:Python數據分析。Python是一種面向對象、直譯式計算機程序設計語言。也是一種功能強大而完善的通用型語言,已經具有十多年的發展歷史,成熟且穩定。Python 具有腳本語言中最豐富和強大的類庫,足以支持絕大多數日常應用。 Python語法簡捷而清晰,具有豐富和強大的類庫。它常被昵稱為膠水語言,它能夠很輕松的把用其他語言製作的各種模塊(尤其是C/C++)輕松地聯結在一起。
課程將從Python的基本使用方法開始,一步步講解,從ETL到各種數據分析方法的使用,並結合實例,讓學員能從中借鑒學習。
課程目錄:
Python基礎
Python的概覽——Python的基本介紹、安裝與基本語法、變數類型與運算符
了解Python流程式控制制——條件、循環語句與其他語句
常用函數——函數的定義與使用方法、主要內置函數的介紹
.....
E. Python 數據分析與數據挖掘是啥
python數據挖掘(data mining,簡稱DM),是指從大量的數據中,通過統計學、人工智慧、機器學習等方法,挖掘出未知的、且有價值的信息和知識的過程。數據分析通常是直接從資料庫取出已有信息,進行一些統計、可視化、文字結論等,最後可能生成一份研究報告性質的東西,以此來輔助決策。數據挖掘不是簡單的認為推測就可以,它往往需要針對大量數據,進行大規模運算,才能得到一些統計學規律。
這里可以使用CDA一站式數據分析平台,融合了數據源適配、ETL數據處理、數據建模、數據分析、數據填報、工作流、門戶、移動應用等核心功能。其中數據分析模塊支持報表分析、敏捷看板、即席報告、幻燈片、酷屏、數據填報、數據挖掘等多種分析手段對數據進行分析、展現、應用。幫助企業發現潛在的信息,挖掘數據的潛在價值。
如果你對於Python學數據挖掘感興趣的話,推薦CDA數據分析師的課程。課程內容兼顧培養解決數據挖掘流程問題的橫向能力以及解決數據挖掘演算法問題的縱向能力。真正理解商業思維,項目思維,能夠遇到問題解決問題;要求學生在使用演算法解決微觀根因分析、預測分析的問題上,根據業務場景來綜合判斷,洞察數據規律,使用正確的數據清洗與特徵工程方法,綜合使用統計分析方法、統計模型、運籌學、機器學習、文本挖掘演算法,而非單一的機器學習演算法。點擊預約免費試聽課。
F. 有用Python寫ETL的嗎
1.目前沒見過吧,但應該有,可以在github上搜一下
2.目前見過最多的etl是java的,如果提供介面的,也可以用python封裝調用
G. 為什麼要用etl工具自己手動寫腳本然後運行不是也可以么
成品ETL工具與手工寫腳本之比較:
一、靈活性來講:ETL工具比較靈活,需要在此平台上設置規則定義,前期是需要工具先前必須已有支持功能,如果需要擴展,要ETL工具源廠商開發。而自己寫腳本只需先前好好調研需求,自己寫能實現的功能即可。俗話說得好「求人不如求己」哈哈哈!
二、難易度:ETL工具相對上手比較容易,工程師只需具備兩個必要條件:1 、對資料庫熟悉 2、對客戶的業務邏輯了解。手動寫腳本呢?不僅要具備操作ETL工具的條件,還要必須有一定技術水平。
三、後期管理與維護:ETL工具非常容易,這點上是用工具的最給力的優勢。可能也是ETL工具誕生的緣由吧!原因:人力少不說,如有新的需求,只需稍加改動,圖形配置定義即可。而手工編碼呢?較難。需要重又開發寫程序,隨著數據信息的日積月累,每日數據的遞增,更新。開發的速度趕不上需求的更新,嚴重到先前開發架構不合理甚至於有可能推倒重來的風險。如果取中間,既有圖形配置有兼具腳本開發功能,有款中國的Beeload/ BeeDI
四、性能和效率:這方面取決於多方面如:1、硬體:伺服器 CPU 內存 2、資料庫類型 數據類型 3、網路狀況 4 、ETL 工具的配置 設計。。。。。整體來說 工具屬於較高范疇,各家成熟ETL 不一致、各有千秋。手工寫腳本就要看編程者的水平啦!因人而異,如果直接在資料庫上寫存儲過興許比任何一家成品工具高得多。在性能上,工具當屬老美的informatica IBM 的DS
五、開發周期:工具只需操作上源廠商負責培訓,再把客戶目前需求了解透徹,周期很短,上線見效快。手工編碼不僅需要把客戶(當前)需求了解透徹,未來需求也要有所預測,再進行開發。這樣周期就不得而知了。
六、工作量:從上述些顯然保守點得出:ETL工具屬中等,手工編碼屬較重。寫好程序還需大量測試工具,不斷修正BUG 與完善。成熟工具已把這些工具先前做過了,即使有,也是可以容忍個別,源廠商可以分擔修正。
七、投入成本價格:ETL工具前期成本投入較多,鈔票先付。後期維護成本相對低。編寫腳本,先期投入人力(工程師的工薪)中期大量測試人力,後期維護人力(工程師的工薪)看似相對較低。貌似不要票子的開源滴ETL工具 Kettle,後期才付費(服務費與培訓費)
總之不管是用工具還是自己寫腳本,要全盤考慮,根據各自項目大小,成本,願意付出哪部分,適合的才是最佳滴!
H. 數據分析員用python做數據分析是怎麼回事,需要用到python中的那些內容,具體是怎麼操作的
大數據!大數據!其實是離不開數據二字,但是總體來講,自己之前對數據的認知是不太夠的,更多是在關注技術的提升上。換句話講,自己是在做技術,這些技術處理的是數據,而不能算是自己是在做數據的。大規模數據的處理是一個非常大的課題,但是這一點更偏向於是搞技術的。
與數據分析相關的Python庫很多,比如Numpy、pandas、matplotlib、scipy等,數據分析的操作包括數據的導入和導出、數據篩選、數據描述、數據處理、統計分析、可視化等等。接下來我們看一下如何利用Python完成數據的分析。
生成數據表
常見的生成方法有兩種,第一種是導入外部數據,第二種是直接寫入數據,Python支持從多種類型的數據導入。在開始使用Python進行數據導入前需要先導入pandas庫,為了方便起見,我們也同時導入Numpy庫。代碼是最簡模式,裡面有很多可選參數設置,例如列名稱、索引列、數據格式等等。
檢查數據表
Python中使用shape函數來查看數據表的維度,也就是行數和列數。你可以使用info函數查看數據表的整體信息,使用dtypes函數來返回數據格式。Isnull是Python中檢驗空值的函數,你可以對整個數據表進行檢查,也可以單獨對某一列進行空值檢查,返回的結果是邏輯值,包含空值返回True,不包含則返回False。使用unique函數查看唯一值,使用Values函數用來查看數據表中的數值。
數據表清洗
Python中處理空值的方法比較靈活,可以使用Dropna函數用來刪除數據表中包含空值的數據,也可以使用fillna函數對空值進行填充。Python中dtype是查看數據格式的函數,與之對應的是astype函數,用來更改數據格式,Rename是更改列名稱的函數,drop_plicates函數刪除重復值,replace函數實現數據替換。
數據預處理
數據預處理是對清洗完的數據進行整理以便後期的統計和分析工作,主要包括數據表的合並、排序、數值分列、數據分組及標記等工作。在Python中可以使用merge函數對兩個數據表進行合並,合並的方式為inner,此外還有left、right和outer方式。使用ort_values函數和sort_index函數完成排序,使用where函數完成數據分組,使用split函數實現分列。
數據提取
主要是使用三個函數:loc、iloc和ix,其中loc函數按標簽值進行提取,iloc按位置進行提取,ix可以同時按標簽和位置進行提取。除了按標簽和位置提起數據以外,還可以按具體的條件進行數據,比如使用loc和isin兩個函數配合使用,按指定條件對數據進行提取。
數據篩選匯總
Python中使用loc函數配合篩選條件來完成篩選功能,配合sum和 count函數還能實現excel中sumif和countif函數的功能。Python中使用的主要函數是groupby和pivot_table。groupby是進行分類匯總的函數,使用方法很簡單,制定要分組的列名稱就可以,也可以同時制定多個列名稱,groupby 按列名稱出現的順序進行分組。