第一节 Python文件类型

源代码

  • Python源代码的文件以“py”为扩展名,由Python程序解释,不需要编译

字节代码

  • Python源文件经编译后生成的扩展名为“pyc”的文件
  • 编译方法

    import py_compile
    py_compile.compile("hello.py")

优化代码

  • 经过优化的源文件,扩展名为“.pyo”
  • python -O -m py_compile hello.py

以上三种均可直接运行

第二节 Python变量

变量的定义

  • 变量是计算机内存中的一块区域,变量可以存储规定范围内的值,而且值可以改变。

变量的命名

  • 变量名有字母、数字、下划线组成。
  • 数字不能开头
  • 不可以使用关键字
  • a a1 a_ a_1

变量的赋值

  • 是变量声明和定义的过程

    a = 1
    ld(a)

第三节 运算符与表达式

案例:写一个自己的四则运算器

#!/usr/bin/python

import sys
running = True while running:
try:
t = int(raw_input())
p = int(raw_input())
except EOFError:
break print 'operator + result\n', t + p
print 'operator - result\n', t - p
print 'operator * result\n', t * p
print 'operator / result\n', t / p

Python运算符包括

  • 赋值运算符

    x = 3, y = 'abcde'      #等于
    x += 2 #加等于
    x -= 2 #减等于
    x *= 2 #乘等于
    x /= 2 #除等于
    x %= 2 #求余等于
  • 算术运算符

    x + y                   #加法
    x - y #减法
    x * y #乘法
    x / y #实数除法
    x // y #整数除法
    x % y #求余
    x**y #求幂
  • 关系运算符

    x < y                   #大于
    x > y #小于
    x <= y #小于等于
    x >= y #大于等于
    x != y #不等于
    x == y #完全等于
  • 逻辑运算符

    and                     #与
    or #或
    not #非

表达式

  • 表达式是将不同数据(包括变量、函数)用运算符按一定规则连接起来的一种式子

运算符的优先级

  • 在常规表达式中,存在着多个运算符,比如:1+2*3-1/2*3/2,那么就存在着计算优先度的问题
  • 一般的,运算符存在高低级别,在同一个表达式中,高优先级的运算符:比如:1*2+3*3 = 11 而不是15
  • 对于同级别的运算符,按从左到右处理。例如:8*4/2*3 = 48
  • 运算符优先级由低到高是:

    Lambda
    逻辑或:or
    逻辑与:and
    逻辑非:not
    成员测试:in not in
    同一性测试:is is not
    比较:< <= > >= != ==
    按位或:|
    按位异或:^
    按位与:&
    移位:<< >>
    加法与减法:+ -
    乘法、除法与取余:* / %
    正负号:+x -x
    按位翻转:~x
    指数:**

第四节 数据类型

案例

  • 123"123"一样吗
  • () [] {}

数据类型

  • 计算机是用来辅助人们的,在程序设计中也映射了现实世界的分类,以便于抽象的分析。
  • 数字
  • 字符串
  • 列表
  • 元组
  • 字典

数字类型

  • 整型
  • 长整形
  • 浮点型
  • 复数型

数字类型-整数int

  • 整数int表示的范围-2147483648到2147483647。例如:0,100,-100
  • int的范围示例:

    num=2147483647
    type(num) #输出结果: <type 'int'>

数字类型-长整数long

  • long的范围很大很大,几乎可以说任意大的整数均可以存储。
  • 为了区分普通整数和长整数,需要在整数后加L或小写l。例如:51856678L, -0x22345L

    num = 11
    type(num) #输出结果: <type 'int'>
    num = 9999999999999999999999
    type(num) #输出结果: <type 'long'>

数字类型-浮点型float

  • 例如:0.0, 12.0, -18.8, 3e+7
  • 示例:

    num = 0.0
    type(num) #输出结果: <type 'float'>
    num = 12
    type(num) #输出结果: <type 'int'>
    num = 12.0
    type(num) #输出结果: <type 'float'>

数字类型-复数型complex

  • Python对复数提供内嵌支持,这是其他大部分软件所没有的
  • 复数举例: 3.14j, 8.32e-36j
  • 示例:

    >>> num=3.14j
    >>> type(num)
    <type 'complex'>
    >>> num
    3.14j
    >>> print num
    3.14j

字符串String

  • 使用引号定义的一组可以包含数字、字母、符号(非特殊系统符号)的集合。

    Strval='This is a test'
    Strval="This is a test"
    Strval="""This is a test"""
  • 三重引号(docstring)通常用来制作字符串,在面向对象时详解

第五节 序列

基本概念

  • 列表、元组和字符串都是序列
  • 序列的两个主要特点是索引操作符和切片操作符。
    • 索引操作符让我们可以从序列中抓取一个特定项目。
    • 切片操作符让我们能够获取序列的一个切片,即一部分序列。
  • 索引同样可以是负数,位置是从序列尾开始计算的。
    • 因此,shoplist[-1]表示序列的最后一个元素,而shoplist[-2]抓取序列的倒数第二个项目
  • 切片操作符是序列名后跟一个方括号,方括号中有一对可选的数字,并用冒号分割。
    • 注意这与你使用的索引操作符十分相似。记住数是可选的,而冒号是必须的。
    • 切片操作符中的第一个数(冒号之前)表示切片开始的位置,第二个数(冒号之后)表示切片到哪里结束。如果不指定第一个数,Python就从序列首开始。如果没有指定第二个数,则Python会停止在序列尾。
    • 注意:返回的序列从开始位置开始,刚好在结束位置之前结束。即开始位置是包含在序列切片中的,而结束位置被排斥在切片外。
      • shoplist[1:3]返回从位置1开始,包括位置2,但是停止在位置3的一个序列切片,因此返回一个含有两个项目的切片。shoplist[:]返回整个序列的拷贝。你可以用负数做切片。负数用在从序列尾开始计算的位置。例如,shoplist[:-1]会返回除了最后一个项目外包含所有项目的序列切片

序列的基本操作

  • len():求序列的长度
  • +:连接两个序列
  • *:重复序列元素
  • in:判断元素是否在序列中
  • max():返回最大值
  • min():返回最小值
  • cmp(tuple1, tuple2):比较两个序列值是否相同

元组()

  • 元组和列表十分类似,只不过元组和字符串一样是不可变的,即你不能修改元组。

    • 元组通过圆括号中用逗号分割的项目定义。
    • 元组通常用在使语句或用户定义的函数能够安全地采用一组值的时候,即被使用的元组的值不会改变。
  • 创建元组
    • 一个空的元组由一对空的圆括号组成,如:myempty=()
    • 含有单个元素的元组,singleton=(2)
    • 一般的元组

      zoo=('wolf', 'elephant', 'penguin')
      new_zoo=('monkey', 'dolphin', zoo)
  • 元组操作
    • 元组和字符串一样属于序列类型,可通过索引和切片操作。
    • 元组值亦不可变

第六节 序列-列表

列表[]

  • list是处理一组有序项目的数据结构,即你可以在一个列表中存储一个序列的项目。
  • 列表是可变类型的数据。
  • 列表的组成:用[]表示列表,包含了多个以逗号分隔开的数字,或者子串。

    list1=['Simon', 'David', 'Clotho']
    list2=[1,2,3,4,5]
    list3=["str1", "str2", "str3", "str4"]

列表操作

  • 取值

    • 切片和索引
    • list[]
  • 添加
    • list.append()
  • 删除
    • del(list[])
    • list.remove(list[])
  • 修改
    • list[]=x
  • 查找
    • var in list
  • 示例:

    >>> list1=['jack', 20, 'male']
    >>> list1
    ['jack', 20, 'male']
    >>> list1.append('USA')
    >>> list1
    ['jack', 20, 'male', 'USA']
    >>> list1.remove('USA')
    >>> list1
    ['jack', 20, 'male']
    >>> help(list1.remove)
    >>> list1[1]=22
    >>> list1
    ['jack', 22, 'male']
    >>> 22 in list1
    True

对象与类快速入门

  • 对象和类,更好的理解列表。
  • 对象=属性+方法
  • 列表是使用对象和类的一个例子
    • 当你使用变量i并给它赋值时候,比如整数5,你可以认为你创建了一个类(类型)int的对象(实例)i。
    • help(int)
  • 类也有方法,即仅仅为类而定义的函数。
    • 仅在该类的对象可以使用这些功能。
    • 例如:
      • Python为list类提供了append方法,这个方法让你在列表尾添加一个项目。
      • mylist.append('an item')列表mylist中增加字符串。注意,使用点号来使用对象的方法。
  • 类也有变量,仅为类而定义的变量
    • 仅在该类的对象可以使用这些变量/名称
    • 通过点号使用,例如mylist.field。

第七节 字典

基本概念

  • 字典是Python中唯一的映射类型(哈希表)。
  • 字典对象是可变的,但是字典的键必须使用不可变的对象,并且一个字典中可以使用不同类型的键值。
  • keys()或者values()返回键列表或值列表。
  • items()返回包含键值对的元值。
  • 示例:

    >>> dict={'name': 'jack', 'age' : 30, 'gender':'male' }
    >>> dict['name']
    'jack'
    >>> dict['age']
    30
    >>> dict['gender']
    'male'
    >>> dict.keys()
    ['gender', 'age', 'name']
    >>> dict.values()
    ['male', 30, 'jack']
    >>> dict.items()
    [('gender', 'male'), ('age', 30), ('name', 'jack')]

创建字典

  • dict = {}
  • 使用工厂方法dict()

    fdict=dict(['x',1], ['y',2])
  • 内建方法:fromkeys(),字典中的元素具有相同的值,默认为None

    ddict={}.fromkeys(('x','y'), -1)
    #输出结果:{'x': -1, 'y': -1}

访问字典中的值

  • 直接使用key访问:key不存在会报错,可以使用has_key()或者in和not in判断,但是has_key方法即将废弃。
  • 循环遍历:for key in dict1.keys():
  • 使用迭代器:for key in dict1:

更新和删除

  • 直接用键值访问更新;内建的update()方法可以将整个字典的内容拷贝到另一个字典中。
  • del dict1['a']:删除字典中键值为a的元素
  • dict1.pop('a'):删除并且返回键为'a'的元素
  • dict1.clear():删除字典所有元素
  • del dict1:删除整个字典

字典相关的内建函数

  • type(), str(), cmp()(cmp很少用于字典的比较,比较依次是字典的大小、键、值)

工厂函数dict()

* 例如:

dict(zip(('x','y'),(1,2)))
dict(x=1,y=2)
#输出结果:{'x': 1, 'y': 2}
  • 使用字典生成字典比用copy慢,因此这种情况下推荐使用copy()

常用函数

  • len():返回序列的大小
  • hash() : 用于判断某个对象是否可以做一个字典的键,非哈希类型报TypeError错误
  • dict.clear(): 删除字典中的所有元素
  • dict.fromkeys(seq, val=None): 以seq中的元素为键创建并返回一个字典,val为制定默认值
  • dict.get(key, default=None): 返回key的value,如果该键不存在返回default指定的值
  • dict.has_key(key):判断字典中是否存在key,建议使用in或not in代替
  • dict.items():返回健值对元组的列表
  • dict.keys():返回字典中键的列表
  • dict.iter*(): iteritems(), iterkeys(), itervalues()返回迭代子而不是列表
  • dict.pop(key[,default]):同get(),区别是若key存在,删除并返回dict[key],若不存在则返回default,未指定值,抛出KeyError异常
  • dict.setdefault(key, default=None):同set(),若key存在则返回其value,若key不存在,则dict[key]=default
  • dict.update(dict2):将dict2中的键值对添加到字典dict中,如果有重复则覆盖,原字典不存在的条目则添加进来。
  • dict.values():返回字典中所有值的列表

第八节 流程控制

if else

  • if语句

    • Python的if语句类似其他语言。if语句包含一个逻辑表达式,使用表达式比较,在比较的结果的基础上作用出决定。

      if expression:
      statement
    • 注:Python使用缩进作为其语句分组的方法,建议使用4个空格代替缩进。
    • 逻辑值(bool)用来表示诸如:对与错,真与假,空与非空的概念
    • 逻辑值包含了两个值:
      • True:表示非空的量(比如:string, tuple, set, dictonary等),所有非零数
      • False:表示0,None,空的量等。
    • 作用:主要用于判读语句中,用来判断
      • 一个字符串是否为空的
      • 一个运算结果是否为零
      • 一个表达式是否可用
  • else语句

    • 语法

      if expression:
      statement
      else:
      statement
    • 如果条件表达式if语句解析为0或false值。else语句是一个可选的语句,并最多只能有一个else语句。

  • elif语句

    • 语法

      if expression:
      statement
      elif expression2:
      statement
      elif expression3:
      statement
      else:
      statement
    • elif语句可以让你检查多个表达式为真值,并执行一个代码块,elif语句是可选的。可以有任意数量的elif。

  • 嵌套的if...elif...else构造

    if expression1:
    statement
    if expression2:
    statement
    else:
    statement
    else:
    statement
  • 使用逻辑运算符and、or、not

    if expression1 and expression2:
    statement
    else:
    statement

for循环

  • 循环是一个结构,导致一个程序重复一定次数。

  • 条件循环也是如此。当条件变为假,循环结束。

  • for循环:
    • 在Python for循环遍历序列,如一个列表或一个字符。
  • for循环语法:

    for iterating_var in sequence:
    statements
  • 注:如果一个序列包含一个表达式列表,它是第一个执行。
    然后,该序列中的第一项赋值给迭代变量iterating_var。接下来,执行语句块。列表中的每个项目分配到iterating_var,代码块被执行,直到整个序列被耗尽。

  • 注:格式遵循代码块缩进原则

  • 例子:

    for letter in 'python':
    print 'Current Letter: ', letter fruits=['banana', 'apple', 'mango']
    for fruit in fruits:
    print 'Current fruit: ', fruit
  • 迭代序列指数(索引):
    • 遍历每个项目的另一种方法是由序列本身的偏移指数(索引)

    • 例子

      fruits=['banana', 'apple', 'mango']
      for index in range(len(fruits)):
      print 'Current fruit: ', fruits[index]
    • 注:‘迭代’,指重复执行一个指令。

range

  • 循环结构是用于迭代多个项的for语句,迭代形式可以循环序列的所有成员。

  • range(i,j[,步进值])
    • 如果所创建的对象为整数,可以用range
    • i为初始数值
    • j为终止数值,但不包括在范围内,步进值为可选参数,不选的话默认是1
    • i不选择的话默认为0
  • 例子:

    sum = 0
    for num in range(1, 101, 1):
    sum += num
    print sum

遍历字典

    dic={'name': 'jack', 'age': 20, 'gender':'male'}
for key in dic:
val = dic[key]
print key,val for key,val in dic.items():
print key, val

for循环控制

    for x in range(10):
if x == 1:
pass
if x == 2:
continue
if x == 5:
break;
else
print 'end'

while循环

  • while循环,直到表达式变为假。表达的是一个逻辑表达式,必须返回一个true或false值

  • 语法:

    while expression:
    statement
  • 注:遵循代码块缩进原则

    while x != 'q':
    x = raw_input('please input something, q for quit: ')
    if not x:
    break
    else:
    print 'end'

第二章 python基础(一)的更多相关文章

  1. 第二章----python基础

    概要:python是一种计算机编程语言,有自己的一套语法,编译器或者解释器负责把符合语法的程序代码翻译成CPU能识别的机器码,然后执行.python使用缩进来组织代码块,Python程序中大小写是敏感 ...

  2. 第二章 Python基础语法

    2.1 环境的安装 解释器:py2 / py3 (环境变量) 开发工具:pycharm 2.2 编码 编码基础 ascii ,英文.符号,8位为一个东西,2**8 unicode ,万国码,可以表示所 ...

  3. 第二章 python基础(二)

    第九节 函数 函数就是完成特定功能的一个语句组,这组语句可以作为一个单位使用,并且给它取一个名字. 可以通过函数名在程序的不同地方多次执行(这通常叫做函数调用),却不需要在所有地方都重复编写这些语句. ...

  4. 第二章 python基础(三)

    第十六节 MySQLdb win64位安装python-mysqldb1.2.5 ubuntu下安装MySQLdb sudo apt-get install python-MySQLdb 导入MySQ ...

  5. 第二章Python入门

    第二章 Python入门 2.1.简介 Python是著名的"龟叔"(Guido van Rossum)在1989年圣诞节期间,为了打发无聊的圣诞节而编写的一个编程语言 Pytho ...

  6. java面向对象编程——第二章 java基础语法

    第二章 java基础语法 1. java关键字 abstract boolean break byte case catch char class const continue default do ...

  7. [Python笔记][第二章Python序列-复杂的数据结构]

    2016/1/27学习内容 第二章 Python序列-复杂的数据结构 堆 import heapq #添加元素进堆 heapq.heappush(heap,n) #小根堆堆顶 heapq.heappo ...

  8. [Python笔记][第二章Python序列-tuple,dict,set]

    2016/1/27学习内容 第二章 Python序列-tuple tuple创建的tips a_tuple=('a',),要这样创建,而不是a_tuple=('a'),后者是一个创建了一个字符 tup ...

  9. [python笔记][第二章Python序列-list]

    2016/1/27学习内容 第二章 Python序列-list list常用操作 list.append(x) list.extend(L) list.insert(index,x) list.rem ...

随机推荐

  1. IE8 兼容 getElementsByClassName

    IE8以下版本没有getElementsByClassName这个方法,以下是兼容写法 function ieGetElementsByClassName() { if (!document.getE ...

  2. onInterceptTouchEvent和onTouchEvent调用时序(转)

    onInterceptTouchEvent和onTouchEvent调用时序 onInterceptTouchEvent()是ViewGroup的一个方法,目的是在系统向该ViewGroup及其各个c ...

  3. sql生成器(含凝视)问题修复版

    接上篇http://blog.csdn.net/panliuwen/article/details/47406455 sql生成器--生成含凝视的sql语句 今天我使用自己写的sql生成器了.自我感觉 ...

  4. java.sql.SQLException: 无法转换为内部表示 -〉java 查询oracle数据库返回错误信息

    java.sql.SQLException: 无法转换为内部表示 Query: SELECT * FROM  nontheasttycoon Parameters: []    at org.apac ...

  5. full stack on the road

    Full Stack, I'm coming. 有人说全栈只是个理想情况,但我不这么认为,因为好多思想是想通的, 比如 OO.函数式编程.设计模式... 也有人说搞全栈的人样样普通,可是为嘛我在学习j ...

  6. Java语言实现简单FTP软件------>源码放送(十三)

    Java语言实现简单FTP软件------>FTP协议分析(一) Java语言实现简单FTP软件------>FTP软件效果图预览之下载功能(二) Java语言实现简单FTP软件----- ...

  7. python+NLTK 自然语言学习处理四:获取文本语料和词汇资源

    在前面我们通过from nltk.book import *的方式获取了一些预定义的文本.本章将讨论各种文本语料库 1 古腾堡语料库 古腾堡是一个大型的电子图书在线网站,网址是http://www.g ...

  8. linux.1:创建分区和文件系统

    概述 使用 fdisk.gdisk 和 parted 创建和修改 MBR 和 GPT 分区在本教程中,学习磁盘分区和 Linux 文件系统相关内容,包括学习如何: 使用 mkfs 命令设置 ext2. ...

  9. vim 一键添加注释 自动添加文件头注释

    估计大家也都和我一样用过不少的编辑器,什么notepad2,emeditor,editplus,ultraedit,vs2005,sourceinsight,slickedit,emacs,vim(g ...

  10. mysql语句优化技巧

    1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引.2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引 ...