mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Thanks jpic for the report and chmodas for working on a patch.
Reverts 2ea80b94. Refs #19362.
Conflicts:
	tests/utils_tests/test_encoding.py
		
	
		
			
				
	
	
		
			37 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # -*- coding: utf-8 -*-
 | |
| """
 | |
| 2. Adding __str__() or __unicode__() to models
 | |
| 
 | |
| Although it's not a strict requirement, each model should have a
 | |
| ``_str__()`` or ``__unicode__()`` method to return a "human-readable"
 | |
| representation of the object. Do this not only for your own sanity when dealing
 | |
| with the interactive prompt, but also because objects' representations are used
 | |
| throughout Django's automatically-generated admin.
 | |
| 
 | |
| Normally,  you should write ``__unicode__()`` method, since this will work for
 | |
| all field types (and Django will automatically provide an appropriate
 | |
| ``__str__()`` method). However, you can write a ``__str__()`` method directly,
 | |
| if you prefer. You must be careful to encode the results correctly, though.
 | |
| """
 | |
| 
 | |
| from django.db import models
 | |
| from django.utils.encoding import python_2_unicode_compatible
 | |
| 
 | |
| 
 | |
| class Article(models.Model):
 | |
|     headline = models.CharField(max_length=100)
 | |
|     pub_date = models.DateTimeField()
 | |
| 
 | |
|     def __str__(self):
 | |
|         # Caution: this is only safe if you are certain that headline will be
 | |
|         # in ASCII.
 | |
|         return self.headline
 | |
| 
 | |
| @python_2_unicode_compatible
 | |
| class InternationalArticle(models.Model):
 | |
|     headline = models.CharField(max_length=100)
 | |
|     pub_date = models.DateTimeField()
 | |
| 
 | |
|     def __str__(self):
 | |
|         return self.headline
 |