1.python2/3區別整除python2:print'3/2=',3/2print'3//2=',3//2print'3/2.0=',3/2.0print'3//2.0=',3//2.0結果:3/2=13//2=13/2.0=1.53//2.0=1.0python3:print('3/2=',3/2)print('3//2=',3//2)print('3/2.0=',3/2.0)print('3//2.0=',3//2.0)3/2=1.53//2=13
系統 2019-09-27 17:53:32 1927
作者:HelloGitHub-ProdesireHelloGitHub的《講解開源項目》系列,項目地址:https://github.com/HelloGitHub-Team/Article前言在前面三篇介紹argparse的文章中,我們全面了解了argparse的能力,相信不少小伙伴們都已經摩拳擦掌,想要打造一個屬于自己的命令行工具。本文將以我們日常工作中最常見的git命令為例,講解如何使用argparse庫來實現一個真正可用的命令行程序。本系列文章默認
系統 2019-09-27 17:52:35 1927
說到流處理,Spark為我們提供了窗口函數,允許在滑動數據窗口上應用轉換,常用場景如每五分鐘商場人流密度、每分鐘流量等等,接下來我們通過畫圖來了解SparkStreaming的窗口函數如何工作的,處理過程圖如下所示:上圖中綠色的小框框是一批一批的數據流,虛線框和實線框分別是前一個窗口和后一個窗口,從圖中可以看出后一個窗口在前一個窗口基礎上移動了兩個批次的數據流,而我們真正通過算子操作的數據其實就是窗口內所有的數據流。在代碼實現前了解下窗口操作常用的函數有:
系統 2019-09-27 17:52:34 1927
1.鎖:Lock(1次放1個)同步鎖線程安全,多線程操作時,內部會讓所有線程排隊處理。如:list/dict/Queue線程不安全+人=>排隊處理。需求:a.創建100個線程,在列表中追加8b.創建100個線程v=[]鎖-把自己的添加到列表中。-在讀取列表的最后一個。解鎖以后鎖一個代碼塊:importthreadingimporttimev=[]lock=threading.Lock()deffunc(arg):lock.acquire()#鎖的區域---
系統 2019-09-27 17:52:33 1927
在配置python環境,并安裝所需包后,運行下列代碼~importpandasaspdfromsqlalchemyimportcreate_engineimportcx_Oracle#進行oracle服務器設置,用戶名;密碼;HOST數據庫IP地址;PORT端口號;SERVICE_NAMEdb=cx_Oracle.connect('userid','password','10.10.1.10:1521/dbinstance')print(db.versio
系統 2019-09-27 17:52:32 1927
Python語言與Perl,C和Java等語言有許多相似之處,也有一定的差異性,以下是Python語言獲取文件后綴名和文件名的方法:#Python獲取文件后綴名的方法importos.pathdeffile_extension(path):returnos.path.splitext(path)[1]printfile_extension('/py/a.py')輸出:.py#Python獲取目錄和文件名importos.pathdeffile_extens
系統 2019-09-27 17:52:22 1927
我們首先來看下python的全部代碼,大家可以直接復制后測試:#-*-encoding:utf-8-*-importloggingimportwmiimportosimporttimefromConfigParserimportConfigParserimportsmtplibfromemail.mime.textimportMIMETextimportsocketfromdatetimeimportdatetimeimportreimportsysimp
系統 2019-09-27 17:52:12 1927
Python實現Mysql數據統計的實例代碼如下所示:importpymysqlimportxlwtexcel=xlwt.Workbook(encoding='utf-8')sheet=excel.add_sheet('Mysql數據庫')sheet.write(0,0,'庫名')sheet.write(0,1,'表名')sheet.write(0,2,'數據條數')db=pymysql.connect('192.168.1.74','root','123
系統 2019-09-27 17:51:52 1927
Python3快速入門(七)——Python3正則表達式1、re模塊簡介re模塊提供Perl風格的正則表達式模式,使Python語言擁有全部的正則表達式功能。2、正則表達式模式模式字符串使用特殊的語法來表示一個正則表達式:正則表達式模式中的字母和數字匹配同樣的字符串;多數字母和數字前加一個反斜杠時會有不同的含義;標點符號通常有特殊的含義,只有被轉義時才匹配自身;反斜杠本身需要使用反斜杠轉義。^匹配字符串的開頭$匹配字符串的末尾.匹配任意字符,除了換行符,當
系統 2019-09-27 17:51:33 1927
前言一般情況下,在函數中可以使用一個裝飾器,但是有時也會有兩個或兩個以上的裝飾器。多個裝飾器裝飾的順序是從里到外(就近原則),而調用的順序是從外到里(就遠原則)。原代碼執行結果裝飾順序:就近原則被裝飾的函數,組裝裝飾器時,是從下往上裝飾執行順序:就遠原則裝飾器調用時是從上往下調用為了更好的理解,找到這段話:被裝飾的函數是一個妹子,裝飾器是衣服。“辦事情”的時候得依次把外套、襯衣、內衣脫掉,事情辦完了還要依次把內衣、襯衣、外套穿上。距離“妹子”越近的裝飾器代
系統 2019-09-27 17:51:26 1927
主機環境:(Python2.7.9/Win8_64/bs4)利用BeautifulSoup4來抓取www.pm25.com上的PM2.5數據,之所以抓取這個網站,是因為上面有城市PM2.5濃度排名(其實真正的原因是,它是百度搜PM2.5出來的第一個網站!)程序里只對比了兩個城市,所以多線程的速度提升并不是很明顯,大家可以弄10個城市并開10個線程試試。最后吐槽一下:上海的空氣質量怎么這么差!!!PM25.py復制代碼代碼如下:#!/usr/bin/envp
系統 2019-09-27 17:51:23 1927
模塊Module定義包含一系列數據、函數、類的文件,通常以.py結尾。作用讓一些相關的數據,函數,類有邏輯的組織在一起,使邏輯結構更加清晰。有利于多人合作開發。導入import1.語法:import模塊名import模塊名as別名2.作用:將某模塊整體導入到當前模塊中3.使用:模塊名.成員fromimport1.語法:from模塊名import成員名[as別名1]作用:將模塊內的一個或多個成員導入到當前模塊的作用域中。fromimport*1.語法:fro
系統 2019-09-27 17:51:00 1927
什么是淺拷貝?先看一個例子a=[1,2,3,4]b=aa.pop(0)print(a)print(b)輸出:[2,3,4][2,3,4]正常對于這種可變對象的這種賦值,會導致a和b指向一個內存地址,而我們將a中的第0個元素剔除后,實質就是改變了對應的內存地址中的數值,所以會導致b也發生變化下面看一下淺拷貝:a=[1,2,3,4]b=a.copy()a.pop(0)print(a)print(b)輸出[2,3,4][1,2,3,4]這種就是淺拷貝,拷貝的列表
系統 2019-09-27 17:50:34 1927
php調用python服務侃侃:公司用的php的popen以命令的形式調用python,首先說說這樣做的缺點。php執行命令行調用python的缺點popen('pythontest.py[參數]','r');缺點一:windows默認的是gbk編碼,當php中傳utf-8中文參數的時候,python接收到的參數會有問題。當然,這是有解決的辦法的,就是windows下轉換一下字符的編碼,linux不用轉換。再來python接收參數的時候肯定也要轉換編碼了,
系統 2019-09-27 17:50:10 1927
記錄三種添加cookie保持接口登錄狀態的方法,方便自己回顧。1.簡單粗暴式。此方法比較小白,前提是已經通過fiddler抓包等方式拿到了cookie,然后直接塞進去。importrequeststrainsUrl='http://XXX.com/trains'headers={"Content-Type":"application/json;charset=UTF-8",}cookies={"XXXthor":"XXXXXX105a42"}prames=
系統 2019-09-27 17:49:54 1927