一、Django外鍵查詢
有下面的表定義
from django.db import models
class Person(models.Model):
name = models.CharField(max_length=64)
age = models.IntegerField()
tel = models.CharField(max_length=64)
@property
def all_cars(self):
return cars.all()
@property
def info(self):
# return the name and tel of person
return '%s %s' % (self.name, self.tel)
class Car(models.Model):
owner = models.Foreignkey(Person, related_name='cars')
name = models.CharField(max_length=64)
price = models.FloatField()
Person表是主表,Car是字表,Car表外鍵至Person表。
子表查詢主表:
car = Car.objects.get(id=1)
# 查詢該車的車主
owner = car.owner
主表查詢子表,即反向查詢:
Tom = Person.objects.get(id=1)
# 查詢此人有多少車
# 方式一:
# Django默認每個主表對象都有一個外鍵的屬性
# 可以通過它來查詢所有屬於主表的子表信息
# 查詢方式:主表.子表_set()
# 返回值爲一個queryset對象
Tom.Car_set().all()
# 方式二:
# 通過在外鍵中設置related_name屬性值既可
Tom.cars.all()
# 方式三:
# 通過@property裝飾器在model中預定義方法實現
Tom.all_cars
二、python json unicode utf-8處理
1、直接輸出字典中文
在python中經常遇見直接print dict(字典),或者dict轉json,但是沒有給特定的參數,然後打印json字符串,輸出的中文就成了unicode碼的情況,如下:
d = {'name': '張三', 'age': '1'}
print d
jd = json.dumps(d)
print jd
# 輸出結果
{'age': '1', 'name': '\xe5\xbc\xa0\xe4\xb8\x89'}
{"age": "1", "name": "\u5f20\u4e09"}
這種情況怎麼辦呢?
要將字典中的中文正確的輸出,可以將d轉換成json字符串,轉換時使用json.dumps(d, ensure_ascii=False, encoding='utf-8'))
d = {'name': '張三', 'age': '1'}
print d
jd = json.dumps(d, ensure_ascii=False, encoding='utf-8'))
print jd
# 輸出結果
{'age': '1', 'name': '\xe5\xbc\xa0\xe4\xb8\x89'}
{"age": "1", "name": "張三"}
來源:https://www.jianshu.com/p/20e078a718ed
https://www.jianshu.com/p/90ecc5987a18