Django–extensions是 Django 的扩展应用,给django开发者提供了许多便捷的扩展工具(extensions),它提供了许多有用的工具和命令行工具,帮助 Django 开发者更高效地进行开发和调试。它的作用包括:
– 提供了更多的Django命令,比如导出数据库、生成数据模型文档、查看URL路由表等;
– 提供了一些有用的Django插件,比如shell_plus插件可以在Shell中自动导入项目的所有模块;
– 提供了一些有用的Django工具,比如graph_models可以将项目的数据模型转换成UML图。
本篇文章介绍它包含哪些有用扩展以及它们的使用场景,django–extensions主要提供了三种扩展:命令扩展,字段扩展和模型扩展。
官方文档:https://django–extensions.readthedocs.io/en/latest/index.html
GitHub:https://github.com/django–extensions/django–extensions
django–extensions安装配置
使用pip安装:pip install django–extensions
[auth]
[django]
[sessions]
包含以下子命令:
admin_generator、clean_pyc、clear_cache、compile_pyc、create_command、create_jobs、create_template_tags、delete_squashed_migrations、describe_form、drop_test_database、dumpscript、export_emails、find_template、generate_password、generate_secret_key、graph_models、list_model_info、list_signals、mail_debug、managestate、merge_model_instances、notes、pipchecker、print_settings、print_user_for_session、raise_test_exception、reset_db、reset_schema、runjob、runjobs、runprofileserver、runscript、runserver_plus、set_default_site、set_fake_emails、set_fake_passwords、shell_plus、show_template_tags、show_urls、sqlcreate、sqldiff、sqldsn、sync_s3、syncdata、unreferenced_files、update_permissions、validate_templates
命令扩展
shell命令的扩展命令,运行Django shell的同时自动加载所有app的models,并选择使用Python shell的版本。
每次进行Django项目调试时,首先需要打开python shell,再重新import每个model。如果安装了django–extensions, 使用python manage.py shell_plus命令将打开一个加强版的django shell,这个shell_plus会自动载入项目中所有的model,可以很方便的开始调试。
检查pip requirements.txt文件中是否有过期的packages,类似于pip list -o,只用于已安装过的packages。
只要提供app label,就会自动为输出定义的Admin Class代码,默认输出在stdout。
python manage.py create_command extension_app
将项目的数据模型转换成UML图,创建基于model的GraphViz2文件。
展示代码中所有的 TODO, FIXME, BUG, HACK, WARNING, NOTE, XXX 的地方。
- Passwd
使用DROP DATABASE和CREATE DATABASE来重置数据库。
目前支持 sqlite3, mysql, postgres,可以用来删除或创建数据库
标准的runserver加上Werkzeug的debugger工具。
展示当前项目可用的template tags和template filters。
- Sqldiff
展示model和数据库是否结构不一样,如果有不一样的地方就展示出来。
- Sqlcreate
根据配置文件(settings.py)的内容生成创建数据库表的SQL语句。
根据settings.py定义的数据库配置,返回一个可以用于其它程序的数据库URI。
- sync_s3
将MEDIA_ROOT的文件复制到S3。
字段扩展
django–extensions提供的最有用的字段扩展:AutoSlugField、RandomCharField和ShortUUIDField。
很多时候需要在url里根据模型某个或多个字段(比如标题,用户名)生成一个独一无二的slug,便于搜索引擎发现内容。AutoSlugField可以很轻松完成这个任务,而且永不重复。比如两篇文章有同样的标题,它会在第2篇文章的slug结尾上加上一个数字。
使用这个字段时先从django–extensions导入,然后指定根据哪些字段生成slug即可。它的强大之处在于它还支持自定义的模型方法和双下划线__关联模型查询。
slug = AutoSlugField(populate_from=[‘title‘, ‘get_description‘, ‘author__username‘])
验证用户身份时经常需要生成一个随机字符串发给用户,有时还需生成随机的邀请码。RandomCharField可以轻松实现这个目的。还可以指定字符串长度和格式。
>>> RandomCharField(length=8, unique=True) BVm9GeaE
>>> RandomCharField(length=4, include_alpha=False) 7097
>>> RandomCharField(length=12, include_punctuation=True) k[ZS.TR,0LHO
>>> RandomCharField(length=12, lowercase=True, include_digits=False) pzolbemetmok
- ShortUUIDField
一个由22个字符组成的字符串,比正常的uuid短了很多。尽管不保证唯一,但重复概率极低。
模型扩展
django–extensions提供的最有用的模型基类扩展:ActivatorModel、TitleDescriptionModel、 TimeStampedModel和TitleSlugDescriptionModel。使用时将模型继承这几个基类即可。
作为基类提供了 status, activate_date,和 deactivate_date 这3个字段。status是一个choice选项,默认是activated。每次当激活或失活一条记录时,日期会自动更新。它还提供了一个自定义Manager方法,允许使用Model.objects.active()查询所有处于活跃状态的对象。
作为基类提供了title 和 description两个字段。title最长255个字符。
作为基类提供了created 和 modified两个字段。这两个字段都是自管理,自动更新的。
作为基类提供了title , description和 slug三个字段,其中slug根据title自动生成,独一无二。
原文地址:https://blog.csdn.net/zhouruifu2015/article/details/130023822
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_45622.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!