作者:心上锁退 | 来源:互联网 | 2014-05-29 08:43
最近花了不到一个星期的时间把Python的官方教程拉了一遍,也算是入门了。因为在单位都是用Java,所以只有空闲时间可以用来学Python,不过因为有编程基础,所以学起来也不算慢。Python的语法很简单,上手很容易。不过因为是直接学Python3,而很多第三方工具包
最近花了不到一个星期的时间把Python的官方教程拉了一遍,也算是入门了。因为在单位都是用Java,所以只有空闲时间可以用来学Python,不过因为有编程基础,所以学起来也不算慢。Python的语法很简单,上手很容易。不过因为是直接学Python3,而很多第三方工具包或框架对3的支持还不够好,所以也碰到不少问题。这里简单总结碰到的一些问题和解决方案。这些问题都是我在window是平台下的CPython3.2.3环境下碰到的。
1.web框架的选择
1)django
应该说django是目前Python最热门的web框架,本来我也是想学这个的。不过看介绍说django目前的版本暂时不支持Python3,后续的1.5版才会提供对3的支持。而且据网上的介绍说django的代码自身的耦合度比较高,不同的部分不容易替换为其他的解决方案,比如ORM部分不好替换为SQLAlchemy。加上这玩意是中量级的框架,所以暂时不考虑。
2)web.py
web.py是个不错的轻量级的框架,没有过度的封装,这点很适合初学者了解基本原理。可惜的是web.py暂时也不支持Python3。
3)Tornado
所以最后选择的就是Tornado,目前版本2.4。这个框架既有web.py的轻量特点,又支持Python3,加上还有不错的成功案例,所以给我的感觉很不错。看了一下官网的介绍,Tornado在Nginx上的性能也相当不错。所以决定先学Tornado。
2.数据库支持
Python上有MySQLdb提供对MySQL数据库的支持,不过很可惜,这玩意也没有提供对Python3的支持。替代方案是MySQL-for-Python-3,这东西其实跟MySQLdb是一回事,可以说是MySQLdb的Python3移植版本,可以再GitHub上找到。用法也和MySQLdb一样。不过在安装的时候,这两个东西的安装都让人费了不少精力和时间。
MySQLdb就不说了,因为2和3的区别还是不少,语法上也有点变化,光靠2to3脚本也不能完全解决这些问题。加上安装的时候这玩意还要读MySQL的注册表项,而我用的是MariaDB,需要改安装配置。折腾完了以后又莫名其妙的发现_mysql这个模块工作不正常,怎么折腾都搞不定。所以最后放弃了。本来以为无望了,后来无意中找到了MySQL-for-Python-3。
MySQL-for-Python-3的安装跟MySQLdb差不多,不过好处就是从Git上fork下来的代码里已经有windows平台安装的脚本可以用。不过值得注意的一点是,代码里含有_mysql的源代码,也就是C的代码,所以系统里必须有C/C++编译器,没有的话就从网上弄一个,不然会提示找不到cl.exe。同时编译的时候注意库文件的路径。安装脚本会从MySQL安装目录的include目录里读取所需的C/C++头文件,但MariaDB把这些玩意放在里面的MySQL文件夹里了,拷出来吧,所以用MariaDB的同学注意了。
折腾一阵子,最后在python的console里来一句import
MySQLdb,然后系统没有报错,大功告成。至此数据库io工具安装完成。这事情折腾了差不多2天。
3.Tornado的Blog Demo
好好看看Demo有时候也是很重要的。Tornado里的Blog写得很简单,事实上我为了学习Spring
Security框架,之前还写过一个类似的东西,不过那个是Java。第一遍看到Tornado的这个Blog系统的时候还是让我很吃惊的,代码量比Java少了不止一星半点,尽管在Spring框架的辅助下,写出这么个玩意同样花不了太多代码。但好就好在,Tornado的框架是侵入式的,所以很多时候你调用的方法函数就是框架本来的接口,因此能直接看到框架的运行机制,而Spring这种框架经过重量级的包装以后,没有文档和源代码,你几乎很难搞明白你的程序背后是怎么运行的。如果是同样的低级别的包装,Servlet
API绝对不可能用这么少的代码量完成这么一个系统。
废话不多说,刚准备运行的时候,就碰上问题,同样是2to3的问题,当然还有别的问题在里面。抛开2和3之间的语法不兼容问题还有部分函数名称有变化,主要问题集中在MySQLdb上。Tornado提供的database模块是对MySQLdb的简单封装,这个封装更加人性化一点。但是问题在于Demo里的SQL语句执行的函数传入的参数写法似乎不一样了。像db.get(sql,*sql_parameters)和db.execute(sql,*sql_parameters)这样的接口,本来是传入两个或更多的参数,第一个参数是sql语句,可以且只能带“%s”占位符,后面所有的参数都是sql语句中的%s占位符表示的参数。但是在我的机器环境下,Demo的的这种写法会报错Syntax
Error。为此我参考了网上的另一种写法,这种写法其实在Python
2里也见过,就是利用字符串占位符,把函数括号里的参数写为像“SELECT XX FROM XX_TABLE WHERE XXX=%s”
%
(a,)这样的形势。这样就不会报错了,但是要注意当SQL语句中占位符所表示的参数类型不是数值型的变量的话,需要把%s占位符用‘’给包起来,否则也会提示出错。在所有的这些改动都做完以后,程序才能正常运行。目前我也不清楚这个问题是MySQL-for-Python-3的问题,还是Python3
的问题,也许应该进一步对MySQL-for-Python-3研究一下。