计算机的操作最终表现是数据的操纵,为了表示和存储数据,都需要对数据进行引用,计算机可以直接从内存地址实现一步访问数据,但是编程的人却没有这种能力。就像人可能够不到在高处的氢气球,但是可以拉动邦在氢气球上的绳子,通过绳子最终实现拿到氢气球。也就是说在计算机中,每个数据都像氢气球一样具有左值,表明数据所在的地址和右值表明数据的具体内容,这就是变量的诞生记。程序员通过变量及变量的多种变化形式实现对内存数据的应用。编程语言中的变量都有自己的特征,例如:数据范围、占用内存的大小、数据在内存中的组织方式,甚至变量支持的操作等。

  变量中的数据是可以根据需要变化的,变量中数据可以被读出,变量中可以写入新的数据。变量主要有:数字类型、字符串类型、列表类型、元组类型和字典类型。

1、数字类型:包括整数类型的简称整型和浮点类型的简称浮点型

  整型变量中只能存储整数,没有小数点的数据;

  浮点型可以存储包括小数点的数据,浮点型数据可以具有取整的操作,例如有如下定义

  num1 = 10

  num2 = 10.3

  print(num1,  num2)或者print(num1, ' , ', num2)

  printf(float(num1), int(num2))

2、字符串类型,就是一串字符,python中规定被一对单引号'或双引号"包括的字符集就是字符串,如果字符串中包括单引号,就必须将字符串用双引号包括

  例如有如下定义:

  name='zhang sanfeng'

  age = 78

  print(name, age)

  结果:

  zhang sanfeng 78

3、列表类型:

  1)、一系列按照顺序排列的元素组成了列表,列表中可以包含字符、数字、字符串、甚至子列表

  2)、和其他语言中的数组不同的是,列表中的数据类型可以不一样

  3)、列表中的长度可以被修改

  4)、列表中的元素也可以被修改

  5)、python中列表用中括号表示[  ]

  6)、列表支持读取、写入、删除、排序、获取长度、统计、获取最大/最小值、清空、复制、赋值、截取、遍历和拼接等操作

  例如有如下定义:

  list1 = [ ]                   //空列表
  list2 = [2, 3, 5, 7]                //数字型列表
  list = ['a', 'b', 'c']
                 //字符串型列表
  list = [1, 4, 2, 'a', [2, 3, 4]]            //包括数字型数据、字符串型数据和列表型数据

  mylist = [2, 3, 5, 7, 11, 13, 17, 19, 'integer', 'string', 'list', [123, 456]]         //这是我们操作的目标

  列表的读取:获取列表中的元素方法:列表名[索引编号],索引从0开始编号,最大值为size - 1,点运算完成获取索引对应的值

  print(mylist[11][0] / mylist[1])            //获取mylist[11]的索引为11的元素,该元素是个列表,继续[0]表示列表中的第0个元素值,其实就是123

  结果:41.0

  print(mylist[8] + ' ' + mylist[9] )               //+完成字符创的拼接

  结果:integer string

  列表的写入:修改mylist列表
  mylist = [2, 3, 5, 7, 11]

  print(mylist)

  结果:[2, 3, 5, 7, 11]

  或者:mylist[4] = 9
  print(mylist)

  结果:[2, 3, 5, 7, 9]               //列表中的元素可以随时被改变,元素的个数也可以被改变

  列表添加元素:用append在列表末尾添加元素,用insert在制定位置添加新元素

  有定义:mylist = [2, 3, 5, 7, 13, 17, 19]
  用append添加元素:mylist.append(23)

  输出列表:print(mylist)

  结果:[2, 3, 5, 7, 13, 17, 19, 23]
  
  mylist.insert(4, 11)
  输出列表:print(mylist)        
  结果:[2, 3, 5, 7, 11, 13, 17, 19, 23]
  列表删除元素:用remove删除指定值的元素,pop删除指定位置的元素,返回删除的元素值

  mylist.remove(2)               //删除列表中第一个指定为2的元素
  print(mylist)

  结果:[3, 5, 7, 11, 13, 17, 19, 23]

  mylist.pop(3)
                //删除指定位置的元素,并返回删除元素的值
  返回结果:11

  print(mylist)

  输出列表:[3, 5, 7, 13, 17, 19, 23]

  del mylist[2]                 //无返回的删除列表中指定索引的元素
  print(mylist)

  [3, 5, 13, 17, 19, 23] 

  列表的排序:用sort函数排序,列表中的数据永久有序,reverse是倒序排序 
  如有定义:names = ['zhangsan', 'lisi', 'wangwu', 'zhaoliu']
  输入列表内容:print(names)            //无序输出
  结果:['zhangsan', 'lisi', 'wangwu', 'zhaoliu']

  names.sort()
                  //正序排序
  排序后的结果输出:print(names)

  ['lisi', 'wangwu', 'zhangsan', 'zhaoliu']
      //已经有序了,而且是按照字母升降的顺序排序
  names.re   tab                //可以借助与tab的自动补全实现简化输入
  names.remove(   names.reverse(   
  倒序排序:names.reverse()

  排序后的结果输出:print(names)

  结果:['zhaoliu', 'zhangsan', 'wangwu', 'lisi']   //倒序后的结果,按照字母顺序

  获取列表的长度:用len完成获取列表长度

  print(len(names))               //获取列表的长度,将列表作为参数传给len即可
  列表长度:4

  获取列表的最值:用max和min函数即可

  print(max(names), min(names))         //获取列表中最大值,最小值
  返回结果:zhaoliu lisi             //最大值zhaoliu   最小值:lisi

  获取列表的统计信息:用count函数即可

  有定义:mylist = [2, 3, 5, 29, 13, 17, 19, 2, 2, 3]
  获取2,3,29,99的统计信息:print(mylist.count(2), mylist.count(3), mylist.count(29), mylist.count(99))
    //列表名.count(num)
  结果:3 2 1 0
  也可以:print(mylist.count(2), mylist.count(mylist[1]), mylist.count(29), mylist.count(99))
        //元素不在,返回0
  结果:3 2 1 0

  获取指定值的列表(第一)索引:用index函数即可

  print(mylist.index(19))               //获取值为19的索引的值
  返回结果:6                  //索引值从0开始

  列表清空:用clear函数即可

  mylist.clear()                   //清空列表
  输出清空后列表的元素:print(mylist)

  结果:[ ]                    //列表已经为空

  列表的复制:用直接赋值是浅复制,两个实际还是一个列表,用copy函数完成深复制,真正是独立的复制情况
  src = [1, 3, 5, 7, 9, 11, 13]             //定义列表src
  des = src
                   //通过赋值符号复制列表,将src赋值并复制到des
  print(src)
                   //输出src列表
  [1, 3, 5, 7, 9, 11, 13]
              //内容没问题
  print(des)
                    //输出des列表
  [1, 3, 5, 7, 9, 11, 13]
              //内容没问题
  des.pop()
                    //删除des列表中最后一个元素
  13                       //返回值13,表示将最后一个元素删除
  print(src, des)                  //输出src和des
  [1, 3, 5, 7, 9, 11] [1, 3, 5, 7, 9, 11]        //结果是src和des中两个列表中的13都被删除了

  如果需要完全独立的复制,则须采用深复制:

  src = [1, 3, 5, 7, 9, 11, 14]             //定义列表src
  print(src)                    //输出src列表
  [1, 3, 5, 7, 9, 11, 14]               //内容没问题
  des = src.copy()                  //通过函数复制列表,将src复制到des

  print(src, des)                  //输出src和des

  [1, 3, 5, 7, 9, 11, 14] [1, 3, 5, 7, 9, 11, 14]     //结果是src和des中两个列表完全一样

  des.pop()                     //删除des列表中最后一个元素
  14                      //返回值13,表示将最后一个元素删除
  print(src, des)                  //输出src和des
  [1, 3, 5, 7, 9, 11, 14] [1, 3, 5, 7, 9, 11]      //结果是src的14还在,而des中中的14都被删除了

  列表的拼接:用+符号即可          //可以先截取再拼接

  print(src + des)               //将src和des拼接
  [1, 3, 5, 7, 9, 11, 14, 1, 3, 5, 7, 9, 11] 

  列表的截取:用:符号即可

  print(src[1:], src[1:5], src[1:5:2])         //截取是有多种表示方式,是开始位置:结束位置:索引距离
  [3, 5, 7, 9, 11, 14] [3, 5, 7, 9] [3, 7]       //开始位置省略从0开始  结束位置缺失到最后一个索引,索引距离缺失表示间隔为1

4、元组类型:与列表很相似,但是元素中的元素不能更改,元组大小是固定的,用小括号表示元组,元组可以被重复赋值
  元组支持的操作比列表少一些,有如下定义:

  mytuple = (3, 5, 7, 9, 11, 13, 'a')

  mytuple.count(3)               //统计3在元组中出现的次数
  结果:1                  //结果为1次

  mytuple.index('a')               //获取值为‘a’的索引
  结果:6                  //结果为6

  mytuple = (1, 2, 3, 4, 5, 6)           //元组内容不能该,可以被二次赋值
  print(mytuple)
                //输出元组内容
  结果:(1, 2, 3, 4, 5, 6) 

    print(mytuple * 2)               //两个元组进行合并了,单个元组内容不改变
  结果:(1, 2, 3, 4, 5, 6, 1, 2, 3, 4, 5, 6)

  print(mytuple)
                //单个元组内容还是一样的
  结果:(1, 2, 3, 4, 5, 6)
  print(mytuple[1:3])               //元组的切片
  结果:(2, 3)

  print(mytuple[1:6:2])
              //元组中指定幅度的切片
  结果:(2, 4, 6)

  mytuple1 = (1, 99, 88, 77)             //定义新的元组

  print(mytuple1 + mytuple)
  结果:(1, 99, 88, 77, 1, 2, 3, 4, 5, 6)      //实现元组的合并

  其实字符串就是只能存储字符的元组,同样无法修改,但是可以统计,返回索引,切片、合并等操作。

5、字典类型

  1)、定义字典时使用大括号

  2)、字典中的元素较键值对

  3)、键值对用x:y的形式表示,x表示键值(关键字),y为元素的值,键在字典中必须唯一且不可改变,不同键值对应的值可以相同

  4)、字典应用时,必须指定键值,返回元素值

  例如有如下定义:

  letters = {1:'a', 2:'b', 3:'c', 4:'d', 'a':123}             //定义字典类型的数据letters
  print(letters)
                        //输出字典letters内容
  结果:{1: 'a', 2: 'b', 3: 'c', 4: 'd', 'a': 123}

  print(letters[2], letters[4], letters['a'])
            //根据键找到值
  结果:b d 123

  print(letters[2], letters[4], letters["a"])
            //字符串用单引号和双引号是一样的
  结果:b d 123  

  letters[5] = 'e'                      //为字典letters添加元素,直接指定键和值即可

  print(letters)                       
  结果:{1: 'a', 2: 'b', 3: 'c', 4: 'd', 'a': 123, 5: 'e'}

  letters['abc']=32
                    //为字典letters添加元素,直接指定键和值即可
  print(letters)    
  结果:{1: 'a', 2: 'b', 3: 'c', 4: 'd', 'a': 123, 5: 'e', 'abc': 32}   //添加元素成功   
  print(len(letters))                     //获取字典的长度
  结果:7

  del letters[2]
                     //删除键为2的元素
  测试字典:print(letters)

  结果:{1: 'a', 3: 'c', 4: 'd', 'a': 123, 5: 'e', 'abc': 32}

  赋值复制--浅复制:letters1 = letters

  测试字典:print(letters1)

  结果:{1: 'a', 3: 'c', 4: 'd', 'a': 123, 5: 'e', 'abc': 32}

  删除键为3的值:del letters1[3]

  测试字典:print(letters1)

  结果:{1: 'a', 4: 'd', 'a': 123, 5: 'e', 'abc': 32}

  测试字典:print(letters)  
  结果:{1: 'a', 4: 'd', 'a': 123, 5: 'e', 'abc': 32}

  复制函数复制--深复制:letters2 = letters.copy()
  测试字典:print(letters2)

  结果:{1: 'a', 4: 'd', 'a': 123, 5: 'e', 'abc': 32}

  删除键为5的值:del letters1[5]

  测试字典:print(letters)

  结果:{1: 'a', 4: 'd', 'a': 123, 'abc': 32}

  测试字典:print(letters1)

  结果:{1: 'a', 4: 'd', 'a': 123, 'abc': 32}

  测试字典:print(letters2)

  结果:{1: 'a', 4: 'd', 'a': 123, 5: 'e', 'abc': 32}

  字典还有很多函数:

  letters.clear( )      letters.get( )        letters.pop(  )       letters.update( )
  letters.copy(  )      letters.items(   )    letters.popitem(     letters.values( )
  letters.fromkeys(  )  letters.keys(   )     letters.setdefault(  )  
  

  

  

python3编程基础之一:量的表示的更多相关文章

  1. python3编程基础之一:关键字

    在学习编程的过程中每种语言都会有一些特殊的字母组合在本语言中表示特定的含义,这种字母组合就是关键字.原则上,关键字是无法被重复定义的,否则,语言在应用中,就无法正确确定标号的意义了. 1.关键字的获取 ...

  2. python3编程基础之一:代码封装

    几乎现代的编程语言都支持函数,函数是代码段的封装,并能实现一特定功能,并能重复使用的代码单位.之前的pow()和sqrt()和print()和input()等类似的内置函数,就是python内部已经实 ...

  3. python3编程基础之一:程序结构

    程序从程序入口进入,到程序执行结束,大体是按照顺序结构执行语句.函数或代码块,掌握程序的结构,有利于把握程序的主体框架. 1.顺序结构--最常见的结构 顺序结构的程序设计是最简单的,只要按照解决问题的 ...

  4. python3编程基础之一:标识符

    每种编程语言都是需要处理数据的,需要变量.函数.类等,而这些都是通过名称访问的.因此,能够作为变量.函数.类等名称的字符串就是标识符.数据,是计算机进行运算的实体.标识符,用来标记的符号,它会指向一个 ...

  5. LinuxShell脚本编程基础2-变量与数值运算、父shell和子shell

    1.变量和数值运算 Shell脚本的变量不需要声明的 对变量赋值有两种方式, 直接用“=” 或者用键盘输入值 #!/bin/bash name1="Jack" echo $name ...

  6. python3编程基础之一:注释模块和包

    1.注释 python中的注释和其他任何编程语言中的注释都不一样,有的注释有特殊要求,而是还是有用的. 1).单行注释:注释以#开始到语句结尾,#号后一般跟一个空格 2).多行注释:文档注释,以&qu ...

  7. python3编程基础之一:操作

    基本操作有:读数据.写数据.运算.控制.输入.输出.语句块 1.读取数据: num1 = 50 num2 = num1 //通过num2取得num1的值,这就是逻辑上的读取 测试数据:print(nu ...

  8. 【C#编程基础学习笔记】6---变量的命名

    2013/7/24 技术qq交流群:JavaDream:251572072  教程下载,在线交流:创梦IT社区:www.credream.com [C#编程基础学习笔记]6---变量的命名 ----- ...

  9. [.net 面向对象编程基础] (5) 基础中的基础——变量和常量

    [.net面向对象编程基础]  (5) 基础中的基础——变量和常量 1.常量:在编译时其值能够确定,并且程序运行过程中值不发生变化的量. 通俗来说,就是定义一个不能改变值的量.既然不能变动值,那就必须 ...

随机推荐

  1. DeepID_V2解读

    港中文汤晓鸥团队在DeepID_v1基础上提出的新版本架构,发表于NIPS2014 一.Architecture 网络架构基本上与DeepId_v1一致. 二.Pipeline 图片被分成20regi ...

  2. OpenStack kilo版(3) Nova部署

    部署在controller和compute节点 配置数据库 MariaDB [(none)]> CREATE DATABASE nova;  Query OK, 1 row affected ( ...

  3. Java中异常关键字throw和throws使用方式的理解

    Java中应用程序在非正常的情况下停止运行主要包含两种方式: Error 和 Exception ,像我们熟知的 OutOfMemoryError 和 IndexOutOfBoundsExceptio ...

  4. python与mysql的数据交互

    一 Python 中操作 MySQL 步骤 1.1 安装pymysql命令 sudo pip3 install pymysql 安装软件:sudo apt-get install 软件名称 安装模块: ...

  5. HTTP 协议部分常识简介

    1.状态码 具体的状态码可以百度查找,但是对于状态码的大致分类有一个清楚的了解 1XX   ----信息状态码------接受的请求正在处理 2XX ------成功状态码 ------请求正常处理完 ...

  6. HTML&CSS基础-ps的基本操作

    HTML&CSS基础-ps的基本操作 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.   我们工作中可能会经常需要将一个图片做成一个网页,而图片中的字体大小,行间距,图中lo ...

  7. [终章]进阶20-流程控制结构--if/case/while结构 - 三个while的存储过程案例(批量生成表单数据) - 随机长度的随机字符串的存储过程案例

    . mysql 存储过程中尽量使用 @变量 而不用局部变量, @变量不容易报错!权限小,更改一下就报错! . sql中判断相等'=' ,用'=' 不用'=='. . #流程控制结构 /* 顺序结构: ...

  8. 大数据之路week07--day03(Hadoop深入理解,JAVA代码编写WordCount程序,以及扩展升级)

    什么是MapReduce 你想数出一摞牌中有多少张黑桃.直观方式是一张一张检查并且数出有多少张是黑桃. MapReduce方法则是: 1.给在座的所有玩家中分配这摞牌 2.让每个玩家数自己手中的牌有几 ...

  9. 大数据之路week06--day07(Hadoop常用命令)

    一.前述 分享一篇hadoop的常用命令的总结,将常用的Hadoop命令总结如下. 二.具体 1.启动hadoop所有进程start-all.sh等价于start-dfs.sh + start-yar ...

  10. Java锁--Semaphore

    转载请注明出处:http://www.cnblogs.com/skywang12345/p/3534050.html Semaphore简介 Semaphore是一个计数信号量,它的本质是一个&quo ...