Django外鍵反向查詢和json_dumps直接輸出中文

一、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

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章