Python学习笔记

jopen 9年前

安装

Linux

Linux已经自带Python了,我的Centos7自带Python2.7.4,我通过源码安装来更新版本。

#!/bin/bash  #源码安装  wget https://www.python.org/ftp/python/2.7.9/Python-2.7.9.tgz  tar -zxvf Python-2.7.9.tgz  cd Python-2.7.9    #编译安装  ./configure  make  make install

安装pip(推荐安装,非必需)

pip是一个包管理器,安装后方便之后框架和依赖包的安装使用。推荐安装。

#!/bin/bash  wget https://bootstrap.pypa.io/get-pip.py  python get-pip.py

Hello World

>>> print 'hello, world'  hello, world  >>> exit()

编辑器

推荐Vim,Windows下使用Notepad++。

hello_world.py

#!/usr/bin/env python  # -*- coding:utf8-*-    # 第一行用于在Linux下被识别从而直接运行  #第二行用于定义此文件的字符编码是utf8,防止乱码,这是一个好习惯    #print可以使用以下两种形式来输出字符到控制台,推荐第二种,可以兼容Python3  print 'Hello World'  print('Hello World')  #可以用逗号分隔每个字符串,打印出来遇到逗号会输出一个空格  print 'Hello','World'    #读取用户输入的字符并赋予name变量  name = raw_input()

运行

python hello_world.py

基础

  • #开头是注释
  • :结尾是代码块,代码块缩进推荐四个空格

数据类型

数字

  • 整数: 例如1100,16进制以0x开头,例如0xff00
  • 浮点数: 例如3.14,科学记数法把10用e替代,1.23x10的9次方的就是1.23e9或者12.3e8
    注:整数运算永远精确,浮点数可能存在四舍五入

字符串

  • 以''或""括起来的任意文本,转义使用\,用于转义单引号、双引号和特殊字符(例如换行符)
  • r''表示原始字符串,不需要转义
  • '''我是内容'''这种三个引号(单双都行)扩起来表示可以换行的文本
  • r'''我是内容'''表示多行原始字符串,不需要转义
  • u''表示Unicode字符串
  • 字符串格式化 'Hello, %s' % 'world'

布尔值

  • True
  • False
    布尔值可以用and、or和not运算

空值

None

变量

变量的类型取决于第一次赋值的类型。

a = 1

常量

Python中无常量,约定全部大写的变量为常量(值依旧可以变)。

PI = 3.14

类型判断和转换

a = '123'  # 判断类型  type(a)  # 转换为int,其他类型同理  int(a)    ## 转换函数表  int(x [,base ])                #将x转换为一个整数  long(x [,base ])             # 将x转换为一个长整数  float(x )                        #将x转换到一个浮点数  complex(real [,imag ])  #创建一个复数  str(x )                           #将对象 x 转换为字符串  repr(x )                        #将对象 x 转换为表达式字符串  eval(str )                      #用来计算在字符串中的有效Python表达式,并返回一个对象  tuple(s )                       #将序列 s 转换为一个元组  list(s )                           #将序列 s 转换为一个列表  chr(x )                          #将一个整数转换为一个字符  unichr(x )                     #将一个整数转换为Unicode字符  ord(x )                          #将一个字符转换为它的整数值  hex(x )                          #将一个整数转换为一个十六进制字符串  oct(x )                           #将一个整数转换为一个八进制字符串

序列

list(列表)

classmates = ['Michael', 'Bob', 'Tracy']  #list中元素个数(得到3)  len(classmates)  #最小元素(得到'Bob')  min(classmates)  #最大元素(得到'Tracy')  max(classmates)  # 访问元素(得到'Michael')  classmates[0]  # 倒数第一个元素(得到'Tracy')  classmates[-1]  # 追加元素  classmates.append('Adam')  # 位置1插入元素,后面元素会依次后推   classmates.insert(1, 'Jack')  # 删除末尾元素  classmates.pop()  # 删除位置 1 的元素  classmates.pop(1)  del classmates[1]  # 删除片段  del classmates[i: j]  # 替换元素  classmates[1] = 'Sarah'  #切片(选取第一个到第二个元素组成新列表)  classmates[1: 2]  #切片(选取第一个到第三个元素组成新列表,每隔两个,按照原始list,得到'Bob')  classmates[1: 3: 2]  # 不同类型元素  L = ['Apple', 123, True]  # list嵌套(list做为list的一个元素)  s = ['python', 'java', ['asp', 'php'], 'scheme']  #取得'php'(相当于二维数组)  print(s[2][2])  #序列连接(两个列表组成新列表)  classmates  + ['lucy', 'joe']  #序列中的元素重复三次  classmates * 3  #元素在列表中是否存在  isHave = 'Bob' in classmates  #转为序列(得到['P', 'y', 't', 'h', 'o', 'n'])  list('Python')

tuple(元组)

一旦定义不可变。获取元素和list相同,如果元组中只有一个元素,必须补一个逗号,用于和运算符区分。

classmates = ('Michael', 'Bob', 'Tracy')  # 单元素元组  classmates = ('Michael',)

dict和set

dict

d = {'Michael': 95, 'Bob': 75, 'Tracy': 85}  #取值(不存在报错)  d['Michael']  #取值,不存在返回`None`   d.get('Thomas')  #取值,不存在返回自定义值`-1`   d.get('Thomas', -1)  #定义值  d['Adam'] = 67  #删除键值对  d.pop('Bob')  del (d['Bob'])  #键列表  dict.keys()  #值列表  dict.values()  #键值对元组列表  dict.items()  #遍历  for (k, v) in dict.items():      print 'dict[%s] =' % k, v

set

不重复的元素集合

#定义,需要将list转化为set,自动过滤重复  s = set([1, 2, 3])  #添加  s.add(4)  #删除  s.remove(4)  #交集  set([1, 2, 3]) & set([2, 3, 4])  #并集  set([1, 2, 3]) | set([2, 3, 4])

条件判断和循环

条件

elif和else都可以省略。条件中非零数值、非空字符串、非空list等,就判断为True,否则为False。

if <条件判断1>:      <执行1>  elif <条件判断2>:      <执行2>  elif <条件判断3>:      <执行3>  else:      <执行4>

循环

#遍历列表  names = ['Michael', 'Bob', 'Tracy']  for name in names:      print name    # 便利列表2  for x in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]:      print x    # 遍历列表3,等效2  for x in range(101):      print x    # while循环(按条件循环)  n = 99  while n > 0:      print n      n = n - 2