zoukankan      html  css  js  c++  java
  • Python基础-列表、元祖、字典、字符串

    列表和分组

    序列概览:

    数据结构是通过某种方式组织在一起的数据元素的集合。这些元素可以是数字、字符,甚至可以是其他数据结构。

    在python中,最基本的数据结构是序列(sequence)。

    序列中的每一个元素被分配一个序号----即元素的位置,也称为索引、下标。第一个索引是0,第二个索引是1,以此类推。

    Python包含6种内建的序列,此次重点讨论最常用的两种类型:列表、元祖。其他内建序列类型包括:字符串、Unicode字符串、buffer对象和xrange对象。接下来讲解对所有序列都通用的操作。

    列表和元祖的创建:

    列表和元祖主要的区别在于:列表可以修改,而元祖不可修改。也就是说如果需要根据要求来添加元素,那么列表可能会更好用;而出于某些原因,序列不能修改时,使用元祖则更为合适。

    创建一个列表,只要把逗号分隔的不同数据项使用方括号括起来即可;

    创建一个元祖,只要把逗号隔开的不同数据项使用小括号括起来即可,如果元组里只有一个元素的话,那么你必须在这个元素后面加一个逗号,否则它不是元组。

    通用序列操作:

    所有序列类型都可以进行某种特定的操作。这些操作包括索引(indexing)、分片(slicing)、加(adding)、乘(multiplying)以及检查某个元素是否属于序列的成员(成员资格),除此之外,还有计算序列长度、找出最大元素和最小元素的内建函数。

    1. 索引

    序列中的所有元素都是有编号的:从0开始递增。这些元素可以通过编号分别访问。这些编号就是索引。索引0指向第一个元素。

    使用负数索引时,python会从右边,就是最后一个元素开始计数。最后一个元素的位置编号就是-1。

    如果一个函数调用返回一个序列,那么可以直接对返回结果进行索引操作。例如你只对用户输入年份的第4个数字感兴趣:

    2.分片

    索引访问单个元素,分片可以访问一定范围的元素。分片通过冒号隔开的两个索引来实现。

    第一个索引是要提取的第一个元素的编号,第二个索引是分片之后剩余部分的第一个元素的编号;简单来说,就是“顾头不顾尾”。

    步长:进行分片的时候,默认步长为1;我们也可以显示设置步长,若步长被设置为大于1的数,则会跳过某些元素。

    例如:步长为2的分片包括的是从开始到结束每隔1个的元素

    步长不可以为0,会报错;但是可以为负数,此时分片从右往左提取元素。

    1、当步长为正数时,开始索引要小于结束索引,否则会取到空

    2、当步长为负数时,开始索引要大于结束索引,否则会取到空

    3、当步长为负数,开始索引为空时,开始索引默认为最后一个索引+1

    4、当步长为负数,结束索引为空时,结束索引默认为0

    3.序列相加

    通过使用加运算符可以进行序列的连接操作。

    只有两种相同类型的序列才能进行连接操作,否则会报错:

    4. 乘法

    用数字X乘以序列,会生成一个新的序列。在新的序列中,原来的序列将被重复X次。

    None、空列表和初始化

    空列表可以简单的通过两个中括号来表示([]).

    None是一个python内建值,代表“这里什么也没有”

    若是想要初始化一个长度为10的列表:

    5.成员资格

    为了检查一个值是否在序列中,可以使用in运算符。

    这个运算符检查某个条件是否为真,然后返回相应的值:条件为真,返回True;条件为假,返回False。

    这样的运算符为布尔运算符,返回的值为布尔值。

     

    6. 长度、最小值、最大值

    len函数:返回序列中所包含的元素的数量

    min函数:返回序列中最小的元素

    max函数:返回序列中最大的元素

    基本的列表操作

    1.改变列表:元素赋值

    使用索引标记为某个特定的、位置明确的元素赋值。

    注:不能为一个位置不存在的元素进行赋值

    如果一个列表长度为5,那么不能为位置为11的的元素赋值。

    2.删除元素

    Del语句实现删除。

    列表方法

    1.append

    append方法适用于在列表末尾追加新的对象。

    在x列表末尾新增一个值为100的对象:

    2.count

    count方法统计某个元素在列表中出现的次数。

    统计x列表中1出现的次数:

    3.index

    index方法用于从列表中找出某个值第一个匹配项的索引位置。

    查找x列表中值为1的元素出现的第一个位置:

    查找的元素不存在时:

    4.insert

    在指定位置插入元素。

    在‘北京’后插入‘香港’:

     

    5.pop

    移除列表中的一个指定的元素(默认是最后一个)。

    移除最后一个元素、移除角标为0的元素:

    pop有返回值:

    6.remove

    移除列表中某个值的第一个匹配项。

    删除x列表中值为1的第一个元素:

    无返回值,与pop相反。

    7.reverse

    将列表中的元素反向存放。

    无返回值,与pop相反。

     

    8.sort

    在原位置对列表进行排序。(字母、汉字都可以排序。)

    升序:列表名.sort();降序:列表名.sort(reverse=True)

    当需要一个排好序的列表副本,同时需要保留原列表不变时,下面这种做法是错误的,因为sort方法不返回值。

    最后得到的是已排序的x和空的y。

    正确的做法是先把x赋值给y:

    字典:

    字典由多个键与其对应的值构成的键-值对组成。键与它的值之间用冒号【:】隔开,项之间用逗号【,】隔开,整个字典由一对大括号括起来【{}】。

    字典中的键是唯一的,值不唯一。字典打印输出是无序的。

     1.查询

    d[k]:返回关联到键k上的值。

    访问字典中不存在的键时会报错:

    get方法:访问字典中不存在的键时,不会报错,而是得到了None。还可以自己定义“默认”值,替换None。

    2.增加

    d[k]=v:将值v关联到键k上。

    如果键k不存在的话,新增一个键k及相应的值;

    如果键k存在的话,覆盖原有的值。

     

    Setdefault方法:类似get方法,能获得与给定键相关联的值,还能在字典中不含有给定键的情况下设定相应的键值。

    当键存在时,返回与其对应的值,不改变字典;

    当键不存在时,更新字典。

    3.删除

    del d[k] :删除键为k的项。

    Pop方法:获得对应于给定键的值,然后将这个键-值对从字典中移除。

     

    4.清空字典

    clear方法:清除字典中所有的项,无返回值(或者说返回None)。

    5.获取字典内容

    print(d.values()) :打印所有值

    print(d.keys()) :打印所有键

    print(d.items()) :打印所有键和对应的值

     

    打印嵌套字典:print(第一个字典名[‘第二个字典’][‘第三个字典’]...[‘list’])

     

    6.循环

    注意:字典元素的顺序通常无序的。

    1)直接循环一个字典的话,循环的是字典的key;

    如果只需要值,可以使用d.values(),

     

    2)同时获取键及键对应的值:

    7.检查d中是否含有键为k的项

    print(key in d) / print(key not in d)

     

    字符串

    1.strip

    返回去除两侧(不包括内部)的空格及换行( )的字符串:

    input().strip() :去掉输入值的空格

    去掉指定的值:

    2.count

    统计字符串出现的次数:

    3.index

    找出某个值第一个匹配项的索引位置。

    4.find

    在字符串中查找子串,返回子串所在位置的最左端的索引。如果没有找到,返回-1。

    5.replace

    替换字符串,将【day】换成【DAY】:

     

    6.isdigit

    判断字符串是否为纯数字

     7.startswith

    判断是否以某个字符串开头

    8.endswith

    判断是否以某个字符串结束

    9.upper:返回字符串的大写字母版

       lower:返回字符串的小写字母版

    10.isalpha

    判断字符串是否全为字

    11.isalnum

    判断是否包含字母和数字,只要有字母或数字就返回True

  • 相关阅读:
    python
    UVA 10891——Game of Sum
    codeforces632E 小偷与商店
    NOIP2007——树网的核
    NOIP2014 提高组 Day2——寻找道路
    nodeoj2000——Freda's Chess
    BZOJ1012——[JSOI2008]最大数maxnumber
    poj2823-Sliding Window
    开博客了,大家好,这是ATHENS的博客。
    Linux简易APR内存池学习笔记(带源码和实例)
  • 原文地址:https://www.cnblogs.com/ruijie/p/8669319.html
Copyright © 2011-2022 走看看