首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >重构长try-except链

重构长try-except链
EN

Stack Overflow用户
提问于 2015-03-05 19:27:40
回答 2查看 175关注 0票数 1

我有一种感觉,这个序列可能写得更短:

代码语言:javascript
复制
dim = Dimension.objects.get(pk=rows['pk'])
try:
    dim.name = rows['name']
except KeyError:
    pass
try:
    dim.external_flg = rows['external_flg']
except:
    pass
try:
    dim.ext_owner = rows['ext_owner']
except KeyError:
    pass
try:
    dim.ext_table_name = rows['ext_table_name']
except KeyError:
    pass
try:
    dim.ext_start_date_column_name = rows['ext_start_date_column_name']
except KeyError:
    pass
try:
    dim.ext_end_date_column_name = rows['ext_end_date_column_name']
except KeyError:
    pass

我从来没有任何Python代码优化和处理异常的经验,但我很高兴能有一个替代的例子如何缩短它。

谢谢!

EN

回答 2

Stack Overflow用户

发布于 2015-03-05 19:33:49

使用dict.get()方法:

代码语言:javascript
复制
dim.name = rows.get('name', dim.name)

或者,对于更干燥的解决方案,将所有赋值放入循环中:

代码语言:javascript
复制
for field_name in ('name', 'external_flg', 'ext_owner', 'ext_table_name',
                   'ext_start_date_column_name', 'ext_end_date_column_name'):
    if field_name in rows:
        setattr(dim, field_name, rows[field_name])

要处理list数据,可以使用类似的循环:

代码语言:javascript
复制
for i, field_name in enumerate(('name', 'external_flg', 'ext_owner',
                                'ext_table_name', 'ext_start_date_column_name',
                                'ext_end_date_column_name')):
    if i < len[rows]:
        setattr(dim, field_name, rows[i])
票数 4
EN

Stack Overflow用户

发布于 2015-03-05 19:37:23

这样的代码应该是有效的--这个答案包含了try/catch块来捕获KeyError :-)

代码语言:javascript
复制
attributes = ['name', 'external_flg', 'ext_owner', 'ext_table_name',
               'ext_start_date_column_name', 'ext_end_date_column_name']

dim = Dimension.objects.get(pk=rows['pk'])

for attr in attributes:
    try:
        setattr(dim, attr, rows[attr])
    except KeyError:
        pass
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28876799

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档