I am starting a new (actually very old) project which I know is in Django. I am getting lost knowing the exact version of Django it has been build upon. Is there a way I can know the version of Django my application is running?
相关问题
- how to define constructor for Python's new Nam
- streaming md5sum of contents of a large remote tar
- How to get the background from multiple images by
- Django __str__ returned non-string (type NoneType)
- Evil ctypes hack in python
This works in Django 1.7:
...which yields (on my machine):
The only way is to take a guess. I would start by looking at the created date of the settings.py file (or other base project files)
Release dates for versions:
Having in your urls.py:[4]
or having an
admin.py
file in an application [5] suggests that it is a 1.0+ project.Having in your urls.py: [6]
would suggest 1.1+.
Having in your settings.py file:
would suggest 1.2+.
[1]: 1.1 release notes
[2]: 1.2 release notes
[3]: 1.3 release notes
[4]: Backwards Incompatible changes 0.96 > 1.0
[5]: Backwards Incompatible changes 0.96 > 1.0
[6]: Multiple databases
I see the answer accepted above and I think it's much easier. Maybe I'm missing something, but this is what I would do.
Open a python terminal that has the Django project on its path.
That version number is strictly for illustration. Yours may differ, I hope.
https://docs.djangoproject.com/en/1.7/intro/tutorial01/:
which gets me the following:
You can guess based on the way settings.py is laid out. Your first hint would be from database settings. The old way prior to Django 1.2 was:
This method is still supported up to 1.3 but now causes Django to complain loudly about it being deprecated.
As of Django 1.2 the following format is used:
While this isn't definitive, it does at least give you a hint to whether your app was written either before or after Django 1.2.
Keep in mind is that an app written against an older version of Django should still work, but you'll likely get a lot of deprecation warnings on the console if your code is referencing stuff that has been deprecated or just moved around.
These warnings can usually safely be ignored in the short-term but you should definitely take time to silence them by updating your code to reference the features in their new home/format. The Django devs do a good job of doing the right thing as far as giving ample time and warning for older functionality to be properly migrated as time goes by.