热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

python学习经验

最近花了不到一个星期的时间把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研究一下。


推荐阅读
  • 优化Flask应用的并发处理:解决Mysql连接过多问题
    本文探讨了在Flask应用中通过优化后端架构来应对高并发请求,特别是针对Mysql 'too many connections' 错误的解决方案。我们将介绍如何利用Redis缓存、Gunicorn多进程和Celery异步任务队列来提升系统的性能和稳定性。 ... [详细]
  • 简化报表生成:EasyReport工具的全面解析
    本文详细介绍了EasyReport,一个易于使用的开源Web报表工具。该工具支持Hadoop、HBase及多种关系型数据库,能够将SQL查询结果转换为HTML表格,并提供Excel导出、图表显示和表头冻结等功能。 ... [详细]
  • Python Django大学生心理健康管理系统开发(含源码、文档)
    本项目包含完整的源代码、设计文档、数据库结构以及详细的安装指南,旨在为计算机专业的学生提供一个全面的心理健康管理系统解决方案。 ... [详细]
  • 本文将详细介绍如何在ThinkPHP6框架中实现多数据库的部署,包括读写分离的策略,以及如何通过负载均衡和MySQL同步技术优化数据库性能。 ... [详细]
  • 全能终端工具推荐:高效、免费、易用
    介绍一款备受好评的全能型终端工具——MobaXterm,它不仅功能强大,而且完全免费,适合各类用户使用。 ... [详细]
  • 本文详细介绍了Django框架内置的对象关系映射(ORM)机制,包括其工作原理、如何连接MySQL数据库以及ORM的主要优势和局限性。同时,提供了配置和使用Django ORM的具体步骤。 ... [详细]
  • 本文介绍了如何在配置了virtualenv和virtualenvwrapper环境后,利用PyCharm创建新的Django项目,并将开发数据库从SQLite切换至更适用于生产环境的MySQL数据库。文章详细记录了尝试使用MySQLdb、MySQL自带Connector及pymysql等不同数据库连接库时遇到的问题及解决办法。 ... [详细]
  • 目录一、salt-job管理#job存放数据目录#缓存时间设置#Others二、returns模块配置job数据入库#配置returns返回值信息#mysql安全设置#创建模块相关 ... [详细]
  • Coursera ML 机器学习
    2019独角兽企业重金招聘Python工程师标准线性回归算法计算过程CostFunction梯度下降算法多变量回归![选择特征](https:static.oschina.n ... [详细]
  • 本文详细介绍了在 Windows 7 系统中配置 Nginx 1.10.3 和 PHP 7.1.1 NTS 的步骤,包括修改 PHP 配置文件、处理依赖项以及创建批处理脚本启动和停止服务。重点解释了如何解决常见的运行时错误。 ... [详细]
  • 本文深入探讨了MySQL中常见的面试问题,包括事务隔离级别、存储引擎选择、索引结构及优化等关键知识点。通过详细解析,帮助读者在面对BAT等大厂面试时更加从容。 ... [详细]
  • 本文详细探讨了Xshell6评估版到期后无法使用的常见问题,并提供了有效的解决方案,包括如何合法购买授权以继续使用。 ... [详细]
  • 日志记录对于软件开发至关重要,特别是在调试和维护阶段。通过日志,开发者能够追踪错误源头并了解系统的运行状态。本文将探讨如何在Django框架中有效配置和使用日志记录功能。 ... [详细]
  • PHP调用Shell命令的多种方法及环境配置指南
    本文详细介绍了在PHP中调用Shell命令的不同方式及其应用场景,同时提供了在Ubuntu系统中配置PHP以支持Shell命令执行的具体步骤。此外,还涵盖了安装与配置Apache服务器及PHP环境的过程,以便于开发者能够顺利地在Web环境中执行Shell脚本。 ... [详细]
  • 深入理解Django中的AJAX应用
    本文详细介绍了AJAX技术及其在Django框架中的应用。AJAX,即异步JavaScript和XML,允许网页在不重新加载整个页面的情况下与服务器交换数据并更新部分网页。 ... [详细]
author-avatar
心上锁退
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有