python - 這段函數如何改寫比較優雅?
問題描述
如圖:
其實就是多了一個判斷而已 ( 但是我因此需要復制2段一樣的代碼 )
具體代碼如下:
def get_all_ranks(df,xm): if xm == '所有':for i in df.index: #如果項目登錄所有(就不做判斷了,直接全部都查詢!!!!) url = df['域名'][i] kw = df['關鍵詞'][i] #查詢一下收錄 df['收錄'][i] = Baidu().baidu_sites(url) #如果沒有收錄 if df[’收錄’][i] != 0:#就不查排名了df['排名'][i]=df['手機排名'][i] = -1 #否則就更新一下排名 else:df['排名'][i] = Baidu().rank(kw,url)[0]df['手機排名'][i]=Baidu().rank(kw,url,zd='m')[0] print ('%s,關鍵詞:%s,pc排名:%s,手機排名%s' % (url,kw,df['排名'][i],df['手機排名'][i]))return dfelse:for i in df.index: if df['項目'][i] == xm:url = df['域名'][i]kw = df['關鍵詞'][i]#查詢一下收錄df['收錄'][i] = Baidu().baidu_sites(url)#如果沒有收錄if df[’收錄’][i] != 0: #就不查排名了 df['排名'][i]=df['手機排名'][i] = -1#否則就更新一下排名else: df['排名'][i] = Baidu().rank(kw,url)[0] df['手機排名'][i]=Baidu().rank(kw,url,zd='m')[0]print ('%s,關鍵詞:%s,pc排名:%s,手機排名%s' % (url,kw,df['排名'][i],df['手機排名'][i]))return df
有高手會改寫得優雅一點嗎? 好像有個裝飾器的東西但是不太會用~
問題解答
回答1:xm的值應該在循環中判斷,并且xm為所有時并不是特殊到值得單獨處理。
for i in df.index: if xm == ’所有’ or xm == i:#do something
相關文章:
1. mac OSX10.12.4 (16E195)下Mysql 5.7.18找不到配置文件my.cnf2. mysql - 怎么生成這個sql表?3. mysql儲存json錯誤4. php - 公眾號文章底部的小程序二維碼如何統計?5. mysql - 表名稱前綴到底有啥用?6. mysql - 數據庫表中,兩個表互為外鍵參考如何解決7. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?8. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?9. mysql - 數據庫建字段,默認值空和empty string有什么區別 11010. sql語句 - 如何在mysql中批量添加用戶?
