python - 這段函數(shù)如何改寫比較優(yōu)雅?
問(wèn)題描述
如圖:
其實(shí)就是多了一個(gè)判斷而已 ( 但是我因此需要復(fù)制2段一樣的代碼 )
具體代碼如下:
def get_all_ranks(df,xm): if xm == '所有':for i in df.index: #如果項(xiàng)目登錄所有(就不做判斷了,直接全部都查詢!!!!) url = df['域名'][i] kw = df['關(guān)鍵詞'][i] #查詢一下收錄 df['收錄'][i] = Baidu().baidu_sites(url) #如果沒(méi)有收錄 if df[’收錄’][i] != 0:#就不查排名了df['排名'][i]=df['手機(jī)排名'][i] = -1 #否則就更新一下排名 else:df['排名'][i] = Baidu().rank(kw,url)[0]df['手機(jī)排名'][i]=Baidu().rank(kw,url,zd='m')[0] print ('%s,關(guān)鍵詞:%s,pc排名:%s,手機(jī)排名%s' % (url,kw,df['排名'][i],df['手機(jī)排名'][i]))return dfelse:for i in df.index: if df['項(xiàng)目'][i] == xm:url = df['域名'][i]kw = df['關(guān)鍵詞'][i]#查詢一下收錄df['收錄'][i] = Baidu().baidu_sites(url)#如果沒(méi)有收錄if df[’收錄’][i] != 0: #就不查排名了 df['排名'][i]=df['手機(jī)排名'][i] = -1#否則就更新一下排名else: df['排名'][i] = Baidu().rank(kw,url)[0] df['手機(jī)排名'][i]=Baidu().rank(kw,url,zd='m')[0]print ('%s,關(guān)鍵詞:%s,pc排名:%s,手機(jī)排名%s' % (url,kw,df['排名'][i],df['手機(jī)排名'][i]))return df
有高手會(huì)改寫得優(yōu)雅一點(diǎn)嗎? 好像有個(gè)裝飾器的東西但是不太會(huì)用~
問(wèn)題解答
回答1:xm的值應(yīng)該在循環(huán)中判斷,并且xm為所有時(shí)并不是特殊到值得單獨(dú)處理。
for i in df.index: if xm == ’所有’ or xm == i:#do something
相關(guān)文章:
1. python - scrapy url去重2. MySQL主鍵沖突時(shí)的更新操作和替換操作在功能上有什么差別(如圖)3. node.js - 微信小程序websocket連接問(wèn)題4. python執(zhí)行cmd命令,怎么讓他執(zhí)行類似Ctrl+C效果將其結(jié)束命令?5. 實(shí)現(xiàn)bing搜索工具urlAPI提交6. Python中使用超長(zhǎng)的List導(dǎo)致內(nèi)存占用過(guò)大7. python - Django有哪些成功項(xiàng)目?8. ios - 類似微博首頁(yè),一張圖的時(shí)候是如何確定圖大小的?9. 數(shù)據(jù)庫(kù) - Mysql的存儲(chǔ)過(guò)程真的是個(gè)坑!求助下面的存儲(chǔ)過(guò)程哪里錯(cuò)啦,實(shí)在是找不到哪里的問(wèn)題了。10. 鏈接圖片時(shí),鏈接不成功
