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. centos - apache配置django报错:cannot be loaded as Python modules2. 微信端电子书翻页效果3. node.js - 有没有比较好的nodejs导出excel的插件?4. css3 - 微信前端页面遇到的transition过渡动画的bug5. mysql - SQL问个基础例子,书上的,我怎么看都看不懂..谁帮我解释一下第2个为什么和第1个一样?6. javascript - 微信小程序里怎么把页面转成图片分享7. mysql事务日志的一些问题8. mysql服务无法启动1067错误,谁知道正确的解决方法?9. mysql - 我用SQL语句 更新 行的时候,发现全部 中文都被清空了,请问怎么解决?10. 数据库 - mysql boolean型无法插入true
