Python / Django根据字符串是否存在来连接字符串

时间:2012-07-01 21:07:51

标签: python django string-concatenation

我正在Django模型上创建一个名为“address”的属性。我希望地址包含我在模型上的多个字段的串联。问题是并非所有这些字段的实例都具有所有这些字段的值。所以,我想只连接那些有值的字段。

最好/最恐怖的方法是什么?

以下是该模型的相关字段:

house = models.IntegerField('House Number', null=True, blank=True)
suf = models.CharField('House Number Suffix', max_length=1, null=True, blank=True)
unit = models.CharField('Address Unit', max_length=7, null=True, blank=True)
stex = models.IntegerField('Address Extention', null=True, blank=True)
stdir = models.CharField('Street Direction', max_length=254, null=True, blank=True)
stnam = models.CharField('Street Name', max_length=30, null=True, blank=True)
stdes = models.CharField('Street Designation', max_length=3, null=True, blank=True)
stdessuf = models.CharField('Street Designation Suffix',max_length=1, null=True, blank=True)

我可以做这样的事情:

def _get_address(self):
    return "%s %s %s %s %s %s %s %s" % (self.house, self.suf, self.unit, self.stex, self.stdir, self.stname, self.stdes, self.stdessuf)

但结果会有额外的空格。

我可以做一系列if语句并在每个语句中连接,但这看起来很难看。

处理这种情况的最佳方法是什么?

感谢。

3 个答案:

答案 0 :(得分:4)

parts = (1, 'a', 'b', 2, 'c', 'd', None, 'f')
# parts = (self.house, self.suf, self.unit, 
#           self.stex, self.stdir, self.stname, 
#           self.stdes, self.stdessuf)
' '.join(str(part) for part in parts if part is not None)
# '1 a b 2 c d e f'

您只需执行列表comp,并检查是否有任何值不是None,并将它们转换为字符串,以便它们无论类型如何都能正确连接。

答案 1 :(得分:2)

我使用生成器来获取非Falsy值,然后加入它们。例如:

parts = (self.house, self.suf, self.unit, self.stex, self.stdir, self.stname, self.stdes, self.stdessuf)
return " ".join(str(s) for s in parts if s is not None)

答案 2 :(得分:2)

" ".join(filter(None, 
               [self.house, self.suf, self.unit, 
                self.stex, self.stdir, self.stname, 
                self.stdes, self.stdessuf]))