存档

‘Python’ 分类的存档

python使用手记:使用pdb调试python程序

2018年9月18日 没有评论

调试是解决问题修复bug最有效的手段,用惯了gdb来调试c/c++代码,那么pdb就是调试python代码的得力助手。

  1. 开始调试

    python -m pdb test.py

  2. 查看、设置断点

    b:查看当前已设置的所有断点

    b [file:]lineNum:在file的lineNum行设置断点

  3. 运行、单步运行、进入函数、运行到下一断点

    run:开始运行程序,进入到脚本的首行

    n:单步运行,不进入当前函数

    s:进入当前函数,然后使用n命令单步调试该函数

    c:继续运行到下一断点出

  4. 查看变量值

    p:查看变量值

  5. 查看当前代码上下文

    l:列出当前代码所在行

  6. 其他
分类: Python 标签: ,

在CentOS或Ubuntu上通过源码安装python3.7

2018年9月14日 没有评论

在CentOS或Ubuntu上安装python3.7的步骤是类似的,区别在于依赖库的安装。具体步骤如下:

1,安装依赖库

  • CentOS

    yum -y install zlib zlib-devel
    yum -y install bzip2 bzip2-devel
    yum -y install ncurses ncurses-devel
    yum -y install readline readline-devel
    yum -y install openssl openssl-devel openssl-static
    yum -y install xz lzma xz-devel
    yum -y install sqlite sqlite-devel
    yum -y install gdbm gdbm-devel
    yum -y install tk tk-devel
    yum -y install libffi-devel

  • Ubuntu

    sudo apt-get install zlib1g-dev libbz2-dev libssl-dev libncurses5-dev libsqlite3-dev libreadline-dev tk-dev libgdbm-dev libdb-dev libpcap-dev xz-utils libexpat1-dev liblzma-dev libffi-dev libc6-dev

2,下载python3.7源码,并编译安装

wget https://www.python.org/ftp/python/3.7.0/Python-3.7.0.tgz && tar xzvf Python-3.7.0.tgz && cd Python-3.7.0 && ./configure –enable-optimizations && make && make install

3,创建软链接

[ -f /usr/local/bin/python3 ] && ln -sf /usr/local/bin/python3 /usr/bin/python3 && ln -sf /usr/bin/python3 /usr/bin/python

分类: Python 标签:

python使用手记:简单示例python面向对象特征

2018年7月27日 没有评论

面向对象三大特征:封装、继承和多态。Python对这三点完美支持。

#封装
class CA(object):
	def __init__(self):
		pass
	def hi(self):
		print("CA")
		
#继承
class CB(CA):
	def __init__(self, msg):
		self.__msg = msg
	def hi(self):
		print("CB: %s" % self.__msg)
		
a = CA()
a.hi()
print(type(a))
b = CB("God")
b.hi()
print(type(b))

#多态
a = b
a.hi()
print(type(a))

			
分类: Python 标签:

python使用手记:如何导入不同目录下的模块

2018年7月26日 没有评论

    模块是python代码重用和隔离的重要组成部分,也是python之所以开发效率高的原因,开源社区提供了大量的模块供我们使用。

    我们可以通过import来导入模块,那么对于不同目录下的模块,如何进行导入操作呢?

    import是以当前执行的python脚本所在目录为初始目录,来搜索相关模块文件的。首先搜索sys.path目录,然后搜索初始目录。

  1. python自带模块
    • 很简单,直接import就行了,比如:import os, datetime, json
  2. 第三方模块
    • 大多数第三方模块可以通过pip来安装,安装之后直接import
  3. 自定义模块
    • 调用同一目录下的模块:
      • /a.py调用/b.py:import b
    • 调用同级目录下的模块
      • /a.py 调用/a/lib/b.py:from lib import b
    • 调用父目录下的模块
      • /test/a.py调用/lib/b.py:

        import sys
        sys.path.append(“..”)
        from lib import b

分类: Python 标签: ,

python3 PyMySQL模块的安装和使用

2017年10月24日 没有评论

我们知道Python3和Python2是不兼容的,版本由2升级到3之后对MySQL数据库的访问也需要使用新的模块。此前的文章中已介绍过MySQLdb在Python2中的用法,今天介绍PyMySQL在Python3中的用法。

  1. 安装
    • 直接通过pip安装:
      pip install PyMySQL
  2. 示例
    • 连接数据库
    import pymysql
    try:
        conn = pymysql.connect(ip, 3306, user, password, db, charset='utf8', cursorclass=pymysql.cursors.DictCursor)
    except Exception as e:
        print("Exception throwed when connect to db: " + str(e))
    • 插入数据
      try:
          with conn.cursor() as cursor:
              sql = "insert into t_student(id, name) values (%d, %s)"
              rows=cursor.execute(sql, (s.id, s.name))
              conn.commit()
      
              if rows == 1:
                  print("Inserted.")
              else:
                  print("Failed")
      except Exception as e:
          print("Exception throwed when insert data: " + str(e))
分类: mysql, Python, 开发 标签: , ,

pyquery:Python版的jQuery,HTML页面解析好工具

2017年9月20日 没有评论
# coding=utf-8

import requests
from pyquery import PyQuery as pq

#set request header
head_req = {
'User-Agent':'Mozilla/5.0 (Linux; U; Android 4.3; en-us; SM-N900T Build/JSS15J) AppleWebKit/534.30 (KHTML, like Gecko) Version/4.0 Mobile Safari/534.30',
'Referer':'http://www.baidu.com/'
}

url = 'http://zhixing.bjtu.edu.cn/portal.php'
r = requests.get(url, headers=head_req)

#build pyquery object from response-content
page = pq(r.content)

#get page title
title = page.find('title')
print title.html()

#get page keyword
kw = page.find('meta[name="keywords"]')
print kw.attr('content')
分类: Python, 开发 标签: ,

阿里云OSS python sdk使用简介

2017年9月20日 没有评论

阿里云OSS可以方便的存储各类数据,配合CDN的使用,能够极大提高数据的访问效率。向OSS存放数据时一般要登陆阿里云,再进入OSS管理控制台,选择bucket上传文件。手动操作步骤还是有点繁琐的。好在阿里为我们提供了api和sdk,能够实现自动化操作。

这里简单介绍一下阿里云OSS-Python-SDK的使用方法。

  1. 安装:pip install oss2
  2. 检查:在Python命令行中输入import oss2;oss2.__version__。安装成功则会显示版本号
  3. 在OSS管理控制台中创建AccessKey
    1. 进入OSS控制管理台首页,点右上侧的AccessKey按钮,打开AccessKey管理控制台
    2. 点击提示框中的“开始使用子用户AccessKey”–>设置用户名–>设置权限,仅选择AliyunOSSFullAccess即可–>开始创建用户–>验证手机号后就创建成功了
    3. 在“访问控制台RAM”页面的“用户管理”中可看到刚才创建的用户,点击用户名
    4. 在“用户详情”页的下边能看到“用户AccessKey”,默认已生成了一个AccessKey
    5. 我们可以随时点右侧的“创建AccessKey”来生成新的AccessKey,创建成功会显示AccessKeyID和AccessKeySecret。这两个参数是通过SDK访问OSS必需的。
  4. SDK的使用,可参考官方手册快速入门,也可以通过官方提供的示例进行测试。下边的代码演示了如何上传一个文档对象到OSS。
    # -*- coding: utf-8 -*-
    import os
    import shutil
    
    import oss2
    
    # 首先初始化AccessKeyId、AccessKeySecret、Endpoint等信息。
    # 把诸如“<你的AccessKeyId>”替换成真实的AccessKeyId等。
    #
    # 以上海区域为例,Endpoint可以是:
    # http://oss-cn-shanghai.aliyuncs.com
    # https://oss-cn-shanghai.aliyuncs.com
    # 分别以HTTP、HTTPS协议访问。
    access_key_id = os.getenv('OSS_TEST_ACCESS_KEY_ID', 'LTdsa52Gjv0Nt6')
    access_key_secret = os.getenv('OSS_TEST_ACCESS_KEY_SECRET', 'dijw14JxbYeeKdaght3DG4w0k96KQBHu')
    bucket_name = os.getenv('OSS_TEST_BUCKET', 'my-bucket')
    endpoint = os.getenv('OSS_TEST_ENDPOINT', 'oss-cn-shanghai.aliyuncs.com')
    
    # 确认上面的参数都填写正确了
    for param in (access_key_id, access_key_secret, bucket_name, endpoint):
        assert '<' not in param, '请设置参数:' + param
    
    # 创建Bucket对象,所有Object相关的接口都可以通过Bucket对象来进行
    bucket = oss2.Bucket(oss2.Auth(access_key_id, access_key_secret), endpoint, bucket_name)
    
    # 上传文件 “本地座右铭.txt” 到OSS,并命名为 “云上座右铭.txt”
    with open(oss2.to_unicode('本地座右铭.txt'), 'rb') as f:
        bucket.put_object('云上座右铭.txt', f)
分类: Python, 开发 标签: , , ,

python2 MySQLdb模块的安装和使用

2016年3月2日 没有评论

本文介绍Python2中添加MySQL模块的方法,及简单使用示例。

  1. 安装准备
    • 依赖库:yum install python-devel mysql-devel openssl-devel
  2. 下载安装包
    • 可以从这里下载MySQL-python-1.2.3c1.tar.gz,提取码:076e
  3. 解压安装
    • tar xzvf MySQL-python-1.2.3c1.tar.gz && cd MySQL-python-1.2.3c1
    • python setup.py build
    • python setup.py install
  4. 简单示例
    • 连接数据库

      import MySQLdb
      conn=MySQLdb.connect(host=DB_SERVER, user=DB_USER, passwd=DB_PASSWD, db=DB_NAME, charset=’utf8′)
      conn.close

    • 查询

      try:
      query=’select id, name from tablea’
      curs.execute(query)
      for row in curs.fetchall():
      print row[1]
      except MySQLdb.Error,e:
      conn.close()

    • 插入
分类: Python 标签: ,

pypinyin:将汉字转为拼音的python库

2016年2月29日 没有评论

Pypinyin是一个简单易用的将汉字转换为拼音的Python库。

安装方法:pip install pypinyin

示例代码:

from pypinyin import pinyin, lazy_pinyin
print ”.join(lazy_pinyin(u’你好,世界’))
#nihao,shijie

分类: Python, 开发 标签: ,

Python学习资料收集

2015年6月23日 没有评论

自己在网上发现的一些比较好的学习Python的资源,记录在这里,备查。

零基础学Python

A Byte of Python

Learn Python The Hard Way

廖雪峰的Python教程

当然,最权威的当是Python官网

分类: Python, 开发, 语言 标签: