python 学习笔记第一天

Python环境 

windows:

1、下载安装包

    https://www.python.org/downloads/

2、安装

    默认安装路径:C:\python27

3、配置环境变量

    【右键计算机】--》【属性】--》【高级系统设置】--》【高级】--》【环境变量】--》【在第二个内容框中找到 变量名为Path 的一行,双击】 --> 【Python安装目录追加到变值值中,用 ; 分割】

    如:原来的值;C:\python27,切记前面有分号

linux:

无需安装,原装Python环境

ps:如果自带2.6,请更新至2.7或3.*版本

 

 

更新Python

windows:

卸载重装即可

linux:

Linux的yum依赖自带Python,为防止错误,此处更新其实就是再安装一个Python

查看默认Python版本

python -V

 

1、安装gcc,用于编译Python源码

    yum install gcc

2、下载源码包,https://www.python.org/ftp/python/

3、解压并进入源码文件

4、编译安装

    ./configure

    make all

    make install

5、查看版本

    /usr/local/bin/python2.7 -V

6、修改默认Python版本

    mv /usr/bin/python /usr/bin/python2.6

    ln -s /usr/local/bin/python2.7 /usr/bin/python

7、防止yum执行异常,修改yum使用的Python版本

    vi /usr/bin/yum

    将头部 #!/usr/bin/python 修改为 #!/usr/bin/python2.6

 

Python 入门

一、第一句Python代码

在 /home/dev/ 目录下创建 hello.py 文件,内容如下:

print "hello,world"

执行 hello.py 文件,即: python /home/dev/hello.py

python内部执行过程如下:

 

二、解释器

上一步中执行 python /home/dev/hello.py 时,明确的指出 hello.py 脚本由 python 解释器来执行。

如果想要类似于执行shell脚本一样执行python脚本,例: ./hello.py ,那么就需要在 hello.py 文件的头部指定解释器,如下:

#!/usr/bin/env python

 

print "hello,world"

如此一来,执行: ./hello.py 即可。

ps:执行前需给予 hello.py 执行权限,chmod 755 hello.py

三、内容编码

python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill)

ASCII(American Standard Code for Information Interchange,美国标准信息交换代码)是基于拉丁字母的一套电脑编码系统,主要用于显示现代英语和其他西欧语言,其最多只能用 8 位来表示(一个字节),即:2**8 = 256,所以,ASCII码最多只能表示 256 个符号。

 

 

显然ASCII码无法将世界上的各种文字和符号全部表示,所以,就需要新出一种可以代表所有字符和符号的编码,即:Unicode

Unicode(统一码、万国码、单一码)是一种在计算机上使用的字符编码。Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,规定虽有的字符和符号最少由 16 位来表示(2个字节),即:2 **16 = 65536,

注:此处说的的是最少2个字节,可能更多

UTF-8,是对Unicode编码的压缩和优化,他不再使用最少使用2个字节,而是将所有的字符和符号进行分类:ascii码中的内容用1个字节保存、欧洲的字符用2个字节保存,东亚的字符用3个字节保存...

所以,python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill),如果是如下代码的话:

报错:ascii码无法表示中文

#!/usr/bin/env python

 

print "你好,世界" 

改正:应该显示的告诉python解释器,用什么编码来执行源代码,即:

#!/usr/bin/env python

# -*- coding: utf-8 -*-

 

print "你好,世界"

四、注释

  当行注视:# 被注释内容

  多行注释:""" 被注释内容 """

五、执行脚本传入参数

Python有大量的模块,从而使得开发Python程序非常简洁。类库有包括三中:

  • Python内部提供的模块
  • 业内开源的模块
  • 程序员自己开发的模块

Python内部提供一个 sys 的模块,其中的 sys.argv 用来捕获执行执行python脚本时传入的参数

#!/usr/bin/env python

# -*- coding: utf-8 -*-

 

import sys

print sys.argv 

六、 pyc 文件

执行Python代码时,如果导入了其他的 .py 文件,那么,执行过程中会自动生成一个与其同名的 .pyc 文件,该文件就是Python解释器编译之后产生的字节码。

ps:代码经过编译可以产生字节码;字节码通过反编译也可以得到代码。

 

七、变量

1、声明变量

#!/usr/bin/env python

# -*- coding: utf-8 -*-

 

name = "wupeiqi"

上述代码声明了一个变量,变量名为: name,变量name的值为:"wupeiqi"

变量的作用:昵称,其代指内存里某个地址中保存的内容

 

变量定义的规则:

  • 变量名只能是 字母、数字或下划线的任意组合
  • 变量名的第一个字符不能是数字
  • 以下关键字不能声明为变量名
  • ['and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'exec', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'print', 'raise', 'return', 'try', 'while', 'with', 'yield']

2、变量的赋值

#!/usr/bin/env python

# -*- coding: utf-8 -*-

 

name1 = "wupeiqi"

name2 = "alex"

#!/usr/bin/env python

# -*- coding: utf-8 -*-

 

name1 = "wupeiqi"

name2 = name1

 

八、输入

#!/usr/bin/env python

# -*- coding: utf-8 -*-

 

# 将用户输入的内容赋值给 name 变量

name = raw_input("请输入用户名:")

 

# 打印输入的内容

print name

输入密码时,如果想要不可见,需要利用getpass 模块中的 getpass方法,即:

#!/usr/bin/env python

# -*- coding: utf-8 -*-

 

import getpass

 

# 将用户输入的内容赋值给 name 变量

pwd = getpass.getpass("请输入密码:")

 

# 打印输入的内容

print pwd

 

九、流程控制和缩进

需求一、用户登陆验证

#!/usr/bin/env python

# -*- coding: encoding -*-

 

# 提示输入用户名和密码

 

# 验证用户名和密码

#     如果错误,则输出用户名或密码错误

#     如果成功,则输出 欢迎,XXX!

 

 

import getpass

 

 

name = raw_input('请输入用户名:')

pwd = getpass.getpass('请输入密码:')

 

if name == "alex" and pwd == "cmd":

    print "欢迎,alex!"

else:

    print "用户名和密码错误"

需求二、根据用户输入内容输出其权限

# 根据用户输入内容打印其权限

 

# alex --> 超级管理员

# eric --> 普通管理员

# tony,rain --> 业务主管

# 其他 --> 普通用户

name = raw_input('请输入用户名:')

 

 

if name == "alex":

    print "超级管理员"

elif name == "eric":

    print "普通管理员"

elif name == "tony" or name == "rain":

    print "业务主管"

else:

    print "普通用户"

十、while循环

1、基本循环

while 条件:

    

    # 循环体

 

    # 如果条件为真,那么循环体则执行

    # 如果条件为假,那么循环体不执行

2、break

break用于退出所有循环

while True:

    print "123"

    break

    print "456"

3、continue

continue用于退出当前循环,继续下一次循环

while True:

    print "123"

    continue

    print "456"

 

以上内容转载自银角大王博客:

http://www.cnblogs.com/wupeiqi/articles/5433925.html

 

1、 python字符介绍

   在C语言中没有字符串,只有字符

   在python中的字符串hello,在C语言中是以字符数组在内存存放['h','e','l','l','o'],如果对字符串修改,则是在内存中新开辟了一段空间进行存放。

   字符串特性:一旦修改,需要重新创建。

   例: "hello" + "ni" + "hao"      内存中:['h','e','l','l','o'] + ['n','i'] + ['h','a','o']

   万恶的“+”,“+”号越多,在内存中多次重复创建,浪费空间。

   C语言需要手动回收,而python,C#等高级语言自带虚拟机会进行GC垃圾回收没有被调用的内存访问空间。

 

2、 python字符串的格式化(占位符)可以节省内存空间

     有如下二种方式,例:

 说明:第二种format方式的效果会更好,性能更好,其实变量a的值没有变,在格式化赋值时会在内存中新开辟空间存放。在python2.7和python3.4中测试结果相同

 

>>> a = 'i am %s,age is %d'
>>> a % ('kony',33)
'i am kony,age is 33'
>>> print(a)
i am %s,age is %d


>>> a = 'i am {0},age is {1}' 
>>> a.format('kony',33) 
'i am kony,age is 33'
>>> print(a)
i am {0},age is {1}

3、 在python中会生成一个缓存池来节省内存空间

      主要存放经常用到的字符串及数字,所以在一定范围内对变量赋同样的值,他们的id值是一样的,当超出这个池的时候,id值则会不同

       分别在python2.7和python3.4版本中进行测试,测试结果如下:(经测试在python2.7和python3.4中效果一样)

       针对字符串,无限制

>>> a = 'asdfsafsafasfsafasdfasfasfasf'
>>> b = 'asdfsafsafasfsafasdfasfasfasf'
>>> id(a),id(b)
(140704388394128, 140704388394128)
>>> a = 'ni'
>>> b = 'ni'
>>> id(a),id(b)
(140704388417416, 140704388417416)

       针对数字,范围:小于-5,大于256

>>> a = -5
>>> b = -5
>>> id(a),id(b)
(8745920, 8745920)

>>> a = -6
>>> b = -6
>>> id(a),id(b)
(140718131946128, 140718131946320)

>>> aa=256
>>> bb=256
>>> id(aa),id(bb)
(8754272, 8754272)

>>> aa = 257     
>>> bb = 257       
>>> id(aa),id(bb)
(19083048, 18637656)

        具体python源码对数字的定义如下:

4、python内部执行过程:

5、print说明:

     Python 2中的print语句被Python 3中的print()函数取代,这意味着在Python 3中必须用括号将需要输出的对象括起来。

     特别说明:经测试在python2.6、python2.7,print作为语句,但已支持括号方式,例:a = 1 print a print(a)均可;

                   在python3.4版本中,print作为函数,只支持括号方式。

          如何限制print的默认换行:

               1、python2版本下,在print输出的最后加个逗号","

               2、python3.4下, print(value, ..., sep=' ', end='\n', file=sys.stdout, flush=False) 设置end为空即可

      建议:为了代码在python2和3上的兼容性,请直接使用print函数括号方式。

 

 

6、用户交互:

     在python2.7版本中

        raw_input:交互输入内容转化为字符串;

        input:交互输入内容不进行转化;

     在python3.4版本中只有input,想要获取数字,需要进行int转变。

     举例:

#_*_ coding:utf-8 _*_

info = 'This var will be printed out ...'
name = raw_input('Please input your name:')
age = int(raw_input('age:'))   
#age = input('age:')
job = raw_input('Job:')
salary  = input('Salary:')
print type(age)

print '''
Personal information of %s:
          Name: %s 
          Age : %d
          Job : %s
        Salary: %d
--------------------------
''' % (name,name, age,job,salary)

 

7、用户输入内容隐藏:

    输入密码时,如果想要不可见,需要利用getpass 模块中的 getpass方法,即:

>>> import getpass
>>> pwd = getpass.getpass("please input the passwd:")
please input the passwd:
>>> print(pwd)
asdfasdfa

 

8、文件操作:   

   python2.7版本中可以用file和open打开文件,  python3.4版本中只有open

       f = open('file_name','r')

       g = file('file_name','r')  

   其中打开模式有'r','w,','a','b','+'

       w:替换重写   a:追加  

       b:二进制文件,主要用于跨平台,来解决window和linux的回车换行区别

       +:用于同时读写

   * 一般会对文件读到的第一行去掉末尾的换行符      f.readline().strip('\n')

   * xreadlines:针对大文件,一行一行读,默认是把全文件读入内存。

   * r+ :读写,默认从文件尾写入,可以由seek跳到指定位置,然后替换文件内容。


   初始文件aa.txt

kony:123:1
wang:22:2
li:311:3


 对python2.7和python3.4测试结果一样。

# _*_ coding: UTF-8 _*_ 

import sys,os
file = sys.argv[1]

f = open(file,'r+')
line_list = f.readlines()

new_list = []
for line in line_list:
    #去掉行尾的换行符
    line = line.strip('\n')
    #对行信息按分隔符进行分列
    value_list = line.split(':')

    #获取最后一字段并数字化
    last_value = int(value_list[-1])
    #对最后一字段进行数字计算
    last_value *= 13

    value_list[-1] = str(last_value)
    #将列表转变为字符串
    new_str = ':'.join(value_list)
    #将循环的改变后的行追加到新的列表
    new_list.append(new_str)
'''
    ######第一种方法按行追加到文件#####
    #按修改后的行追加到文件中
    #f.writelines(new_str + '\n')
'''
'''
#####第二种方法将所有行统一追加到文件#####
#将所有修改后的新列表转化为字符串
my_str = '\n'.join(new_list)
#将指标移到行首
f.seek(0)
#将写回到文件
f.write(my_str + '\n')
'''
f.close()

 

 

9、类型转变:

 

Python 有办法将任意值转为字符串:将它传入repr() 或str() 函数。

函数str() 用于将值转化为适于人阅读的形式,而repr() 转化为供解释器读取的形式(如果没有等价的
语法,则会发生SyntaxError 异常) 某对象没有适于人阅读的解释形式的话, str() 会返回与repr()等同的值。很多类型,诸如数值或链表、字典这样的结构,针对各函数都有着统一的解读方式。字符串和浮点数,有着独特的解读方式。
Some examples:


下面有些例子
>>> s = 'Hello, world.'
>>> str(s)
'Hello, world.'
>>> repr(s)
"'Hello, world.'"
>>> str(1.0/7.0)
'0.142857142857'
>>> repr(1.0/7.0)
'0.14285714285714285'

 

posted @ 2016-05-28 08:53  PY-Kony  阅读(124)  评论(0)    收藏  举报