Things I hate about Python and Django
I have been a PHP programmer for the last 9 years, and only in September of 2009 I switched to Python and the Django framework. While I really love the Python language and the Django framework (especially compared to something like the Zend PHP framework), there are a couple of things that are really bugging me.
Python
- The lack of public, private and protected functions. Yes, there is a convention to use an underscore for private methods, but it seems very old-fashioned to me.
- Static functions are overly complicated to use in my opinion.
- Why do all methods need to be given a “self” as their first parameter. I mean really..? Why can’t this be automagically done?
', '.join(list)
. No matter how you this explain this to me, it’s still backwards.- No
switch
statement. You can replicate its functionality using a dictionary, but it is harder to read, and a lot harder to write. - Dictionaries are unordered. Argh! Very, very annoying.
- The official Python documentation. I guess I am spoiled having used the very impressive official PHP documentation for so long, but really Python could use more work on this.
- Not everything is consistently done in a object oriented fashion: why is it
len(['list'])
andlen("string")
, and not['list'].len()
and"string".len()
? - All the underscores and
__init__.py
files. - Tuples must die. They are ugly, especially when you only have one item in it and it needs that dangling comma:
('item',)
Django
- The template language has some very strong points, but simple things like variable variables are impossible without writing your own template tags. For example, within a loop I’d like to be able to do something like
{{ my_dict.{{ variable }} }}
. - The code style, in particular all the function_names_with_underscores. I always use mixedCaseNames, and now everything looks like crap.
- It gets annoying having to restart your webserver after you change code. Thank God for the awesome development server that comes with Django at least.
- Why can I use a
{% block %}
only once in my template? Maybe I want to show a block (like a title) twice on the same page. I know the technical reason for this limitation, but with Jinja2 templates for example you can at least show a previously defined block again. - Because much of your Python code is only executed once (after which only the compiled result is executed), sometimes it is overly complicated to write a function that is executed on every hit.
It’s not all bad
I’d like to end on a positive note though with the things I love about Python and Django.
- Significant whitespace. It makes other peoples Python code much easier to read, even though I still miss the closing brackets some times. They just make it easier to see where your block ends.
- Keyword arguments. All languages should have them!
- The community is great, both Python and Django (and Plone!)
- Url configs, and how easy it is to create a beautiful url that links to a view.
- Extending templates makes it easy to organize your html code
- The Django documentation is very good. In fact, I think I have never seen an open source project with better documentation!
- The thing I love most about Django has to be its buildin generic views like direct_to_template, object_list, object_detail, etc. It’s so easy to create a view that shows a paginated list of items, or a view that uses a date in your url like /blog/2009/03.
- And last but certainly not least: the buildin admin site. It just saves you so much time!