-1

以下は私のモデルです:

私は2つのテーブルを持っていmatchますteam

class Match(DictModel):
    date_time = db.DateTimeProperty()
    team1 = db.StringProperty()
    team2 = db.StringProperty()
    venue = db.StringProperty()
    result = db.IntegerProperty()

class Team(DictModel):
    tslug = db.StringProperty()
    name = db.StringProperty()
    matches_played = db.IntegerProperty()
    matches_won = db.IntegerProperty()
    rating = db.FloatProperty()

実行時に、ハンドラー関数の1つにPOSTリクエストが行われたときに、チームの評価をのクエリセットに動的に関連付けMatchて値を送信したいのですが、これが私がやろうとしている方法です。

matches = Match.all()
      matches.filter('date_time <=', end)
      matches.filter('date_time >=', start)
      match_dict = functs.create_dict(matches)
      self.response.out.write(match_dict)

現在のチームから評価を取得するカスタム関数があります。次のとおりです。

def to_dict(self):
       return dict([(p, unicode(getattr(self, p))) for p in self.properties()])

def create_dict(matches):
  lst = []
  for m in matches:
    t1 = m.team1
    t2 = m.team2
    te1 = Team.all().filter("name =", t1).get()
    te2 = Team.all().filter("name =", t2).get()
    m.setattr('rating1', te1.rating)
    m.setattr('rating2', te2.rating)
    lst.append(m)
  data_dict = json.dumps([l.to_dict() for l in lst])
  return data_dict

トラブル:私も試しsetattrた代わりにエラーが発生しますが、それでもうまくいかないようです。他のすべては完璧に機能しています。setattrm.rating1 = te1m.rating2 = te2

助けてください!

4

1 に答える 1

0

構文はsetattr(m、'rating1'、te1.rating1);です。ただし、これはm.rating1=te1.rating1と同じです。

トレースバックを見せてもらえますか?

于 2012-04-15T04:28:28.677 に答える