• python 1Day


    安装Python环境

    windows:

    1
    2
    3
    4
    5
    6
    7
    1、下载安装包
        https://www.python.org/downloads/
    2、安装
        默认安装路径:C:python27
    3、配置环境变量
        【右键计算机】--》【属性】--》【高级系统设置】--》【高级】--》【环境变量】--》【在第二个内容框中找到 变量名为Path 的一行,双击】 --> 【Python安装目录追加到变值值中,用 ; 分割】
        如:原来的值;C:python27,切记前面有分号

    linux:

    1
    2
    3
    无需安装,原装Python环境
      
    ps:如果自带2.6,请更新至2.7

    更新Python

    windows:

    1
    卸载重装即可

    linux:

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

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    查看默认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/python3.5 -V
    6、修改默认Python版本
        mv /usr/bin/python /usr/bin/python2.6
        ln -/usr/local/bin/python3.5 /usr/bin/python

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

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

    Python 入门

    一、第一句Python代码

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

    1
    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 文件的头部指定解释器,如下:

    1
    2
    3
    #!/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码无法表示中文

    1
    2
    3
    #!/usr/bin/env python
      
    print "你好,世界"

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

    1
    2
    3
    4
    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
      
    print "你好,世界"

    四、注释

      当行注视:# 被注释内容

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

    五、执行脚本传入参数

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

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

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

    1
    2
    3
    4
    5
    6
    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
      
    import sys
      
    print sys.argv 

    六、 pyc 文件

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

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

    七、变量

    1、声明变量

    1
    2
    3
    4
    #!/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
     
    八、输入
    1
    2
    3
    4
    5
    6
    7
    8
    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
      
    # 将用户输入的内容赋值给 name 变量
    name = raw_input("请输入用户名:")
      
    # 打印输入的内容
    print name

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

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
      
    import getpass
      
    # 将用户输入的内容赋值给 name 变量
    pwd = getpass.getpass("请输入密码:")
      
    # 打印输入的内容
    print pwd

    九、流程控制和缩进

    需求一、用户登陆验证

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    #!/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 "用户名和密码错误"

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

    1
    2
    3
    4
    5
    6
    # 根据用户输入内容打印其权限
      
    # alex --> 超级管理员
    # eric --> 普通管理员
    # tony,rain --> 业务主管
    # 其他 --> 普通用户
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    name = raw_input('请输入用户名:')
      
      
    if name == "alex"
        print "超级管理员"
    elif name == "eric":
        print "普通管理员"
    elif name == "tony" or name == "rain":
        print "业务主管"
    else:
        print "普通用户"

    十、while循环

    1、基本循环

    1
    2
    3
    4
    5
    6
    while 条件:
         
        # 循环体
     
        # 如果条件为真,那么循环体则执行
        # 如果条件为假,那么循环体不执行

    2、break

    break用于退出所有循环

    1
    2
    3
    4
    while True:
        print "123"
        break
        print "456"

    3、continue

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

     
    1
    2
    3
    4
    while True:
        print "123"
        continue
        print "456"
       
       
     

    4. 运算符
      注意:
        a.

          i += 1

        b. 
          if 1 == 1 or 1 > 2 and 1 == 4:
          print('正确')
          else:
          print('错误')

        c.
          content = "Alex 前几天去泰国玩姑娘,一不小心染上了病,他的内心活动是,真该多来几个"

          if "前几天去" in content:
          print('包含敏感字符')
          else:
          print(content)

    5. Python数据类型
        a. 整数 int
         - 创建
          a = 123
          a = int(123)
          - 转换
          age = "18"
          new_age = int(age)
        b. 布尔值 
          - 创建
          a = True
          b = False
          - 转换
          - 数字转换,只有0是False,其他True
          - 字符串, 只有""是False,其他True

         c. 字符串
          - 创建
          a = "alex"
          a = str('alex')
        - 转换
          age = 19
          new_age = str(age)
        - 字符串的拼接
          name = 'alex'
          gender = '女'
          new_str = name + gender
          print(new_str)

        - 字符串格式化 
          # 占位符,
          # name = '我叫李杰,性别:%s,我今年%s岁,我在说谎!'
          # new_str = name %('男',19,)
          # print(new_str)

          name = '我叫李杰,性别:%s,我今年%s岁,我在说谎!' %('男',19,)
          print(name)

        - 判断子序列是否在其中

          content = "Alex 前几天去泰国玩姑娘,一不小心染上了病,他的内心活动是,真该多来几个"

          if "前几天去" in content:
          print('包含敏感字符')
          else:
          print(content)

        - 移除空白
          val = " alex "
          print(val)
          # new_val = val.strip() # 左右
          # new_val = val.lstrip()# 左边
          # new_val = val.rstrip() # 右边
          # print(new_val)
        - 分割
          user_info = "alex sb123 9"
          # v = user_info.split('|')
          # v = user_info.split('|',1)
          # v = user_info.rsplit(' ',1)
          # print(v)
        - 长度(字符)
          val = "李杰sb"
          v = len(val)
          print(v)
        - 索引
          val = "李杰sb"
          v = val[0]
          print(v)

          val = input('>>>')
          i = 0
          while i < len(val):
          print(val[i])
          i += 1
        - 切片
          name = '我叫李杰,性别我今年岁,我在说谎!'
          print(name[0])
          print(name[0:2])
          print(name[5:9])
          print(name[5:])
          print(name[5:-2])
          print(name[-2:])

       d. 列表
        创建:
          a = ['alex','狗','eric',123]
          a = list(['alex','狗','eric',123])

        in判断:
          if 'al' in a:
          pass
          if 'al' in a[0]:
          pass

        索引:
          val = a[0]
        长度:
          val = len(a)

        切片:
          a = ['alex','狗','eric',123]
          v = a[0::2]
          print(v)

        追加:
          a = ['alex','狗','eric',123]
          a.append('xxoo')
          print(a)
          插入:
          a = ['alex','狗','eric',123]
          a.insert(0,'牛')
          print(a)
        删除:
          a = ['alex','eric','狗','eric',123]
          # a.remove('eric')
          del a[0]
          print(a)

        更新:
          a = ['alex','eric','狗','eric',123]
          a[1] = '阿斯顿发送到'
          print(a)

        For循环:
          a = ['alex','eric','狗','eric',123]
          for item in a:
          print(item)
          # break
          # continue

    e. 字典操作
        - 创建
          v = {
          'name': 'alex',
          'password': '123123'
          }

        # 常用操作

        # 索引获取值
        # n = v['name']
        # print(n)

        # 增加,无,增加;有,修改
        # v['age'] = 19
        # print(v)

        # 删除
        # del v['name']
        # print(v)

        # 循环
        # for item in v.keys():
        # print(item)
        # for item in v.values():
        # print(item)
        # for key,val in v.items():
        # print(key,val)
        print(len(user_dict))

        PS: 相互嵌套
        user_dict = {
         'k1': 'v1',
         'k2': {'kk1':'vv1','kk2':'vv2'},
        'k3': 123,
        'k4': ['alex','eric',['a','b','c'],'李杰',{'k11':'vv1'}],
        }
        user_dict['k4'][2].append('123')
        user_dict['k4'][4]['n'] = '过啥龙'


    应用:

    user_list = [
    {'name':'alex','pwd':'123123','times':1},
    {'name':'eric','pwd':'123123','times':1},
    {'name':'tony','pwd':'123123','times':1},
    ]
    user = input('用户名:')
    pwd = input('密码:')
    for item in user_list:
    if user == item['name'] and pwd == item['pwd']:
    print('登录成功')
    break

    示例:
    db
    alex|123123|3
    eric|123123|3

    login.py

    #!/usr/bin/python
    # -*- coding:utf-8 -*-
    # 1. 打开并读取文件内容
    f1 = open('db','r')
    data = f1.read()
    f1.close()

    # 2. 格式化,列表中嵌套字典
    print(data)
    user_info_list = []
    user_str_list = data.split(' ')
    for item in user_str_list:
    temp = item.split('|')
    v = {
    'name': temp[0],
    'pwd': temp[1],
    'times': temp[2]
    }
    user_info_list.append(v)
    user_info_list[1]['times'] = 3
    print(user_info_list)

    # 3. 列表中嵌套的字典


    #
    # 4. 重新写入文件
    target = """alex|123123|3 eric|123123|3"""

    f2 = open('db','w')
    f2.write(target)
    f2.close()

  • 相关阅读:
    [已解决]报错:报错AttributeError: 'int' object has no attribute 'upper'
    Pandas之read_excel()和to_excel()函数解析
    [已解决]报错This event loop is already running
    [转]NMON服务器监控、指标说明
    LoadRunner编程之跳出迭代
    sqlplus与shell互相传值的几种情况
    Loadrunner中socket协议中的三个关联函数
    ORACLE expdp/impdp导出实例
    Linux下的split 命令(将一个大文件根据行数平均分成若干个小文件)
    批量快速的导入导出Oracle的数据(spool缓冲池、java实现)
  • 原文地址:https://www.cnblogs.com/zhangchaoya/p/6816064.html
Copyright © 2020-2023  润新知