Python基础 6 ---- Python 元组+列表+字典+文件

简介: 本文转载自点击打开链接      Python的元组、列表、字典数据类型是Python内置的数据结构。这些结构都是经过足够优化后的,所以如果使用好的话,在某些地方将会有很大的益处。

本文转载自点击打开链接


     Python的元组、列表、字典数据类型是Python内置的数据结构。这些结构都是经过足够优化后的,所以如果使用好的话,在某些地方将会有很大的益处。


1元组

     个人认为就像C++的数组,Python中的元组有以下特性

  • 任意对象的有序集合,这条没啥说的,数组的同性
  • 通过偏移读取
  • 一旦生成,不可改变
  • 固定长度,支持嵌套
    代码:
    >>> (0, 'haha', (4j, 'y'))   
    (0, 'haha', (4j, 'y'))   
    >>> t = (1, 3, 'b')   
    >>> t[2]   
    'b'   
    >>> t[3]   
      
    Traceback (most recent call last):   
      File "#41>", line 1, in <module></module>   
        t[3]   
    IndexError: tuple index out of range  
    >>> t[-1]   
    'b'   
    >>> t[0:-1]   
    (1, 3)   
    >>> t * 2   
    (1, 3, 'b', 1, 3, 'b')   
    >>> for x in t:   
        print x,   
      
           
    1 3 b   
    >>> 'b' in t   
    True  
    >>> q = t + ((3, 'abc'))   
    >>> q   
    (1, 3, 'b', 3, 'abc')   
    >>> for x in (2, (3, 'a')):   
        print x   
      
           
    2   
    (3, 'a')   
    >>> len(q)   
    5   
    >>> len((2, (3, 'abc')))   
    2   
    >>> (1, 2, 3)[1]   
    2   
    >>> q[1] = 'd'   
      
    Traceback (most recent call last):   
      File "#57>", line 1, in <module></module>   
        q[1] = 'd'   
    TypeError: 'tuple' object does not support item assignment   
    >>> a = ('b', 'c', q)   
    >>> 1 in a   
    False  
    >>> q in a   
    True  
    >>> a   
    ('b', 'c', (1, 3, 'b', 3, 'abc'))   
    >>> q='d'   
    >>> a   
    ('b', 'c', (1, 3, 'b', 3, 'abc')) 

上面的例子足以说明大部分了,使用元组时最重要的一点是“一旦生成,就不可变了”。


2 列表

     列表就像C++里的vector,所具有的特性也要比元组更多,更灵活,其特点总结如下

  • 任意对象的有序集合
  • 可通过偏移存取,注意,列表中的元素都是可变的,这是不同于元组的
  • 长度可变,支持嵌套
  • 还有一些类似java的对象引用机制

      由于列表的这些特性,使得列表在实际应用中被广泛使用,下面是一些例子。

 (1) 首先是基本用法

  代码
    >>> l = ['a', 'b', 'c']   
    >>> len(l)   
    3   
    >>> l + ['d']   
    ['a', 'b', 'c', 'd']   
    >>> l * 2   
    ['a', 'b', 'c', 'a', 'b', 'c']   
    >>> for x in l:   
        print x,   
                 
    a b c 

 

 (2) 索引和分片,赋值(单个元素赋值,分片赋值)

   代码
>>> l = ['abc', 'def', 'ghi', 123]         
    >>> l[2]         
    'ghi'         
    >>> l[-3]         
    'def'         
    >>> l[:3]         
    ['abc', 'def', 'ghi']       
    >>> l[1] = 'haha'      
    >>> l      
    ['abc', 'haha', 'ghi', 123]      
    >>> l[1:] = ['apple', 'banana']      
    >>> l      
    ['abc', 'apple', 'banana']      
    >>> l[2] = [123, 345, 456]      
    >>> l      
    ['abc', 'apple', [123, 345, 456]]      
    >>> l[1:] = [123, 234, 345, 456, 567]      
    >>> l      
    ['abc', 123, 234, 345, 456, 567] 

 

 (3) 添加、排序、删除操作

  代码
   >>> l = ['abc', 'def', 'ghi', 123]   
    >>> l.append(456)   
    >>> l   
    ['abc', 'def', 'ghi', 123, 456]   
    >>> l.sort()   
    >>> l   
    [123, 456, 'abc', 'def', 'ghi']   
    >>> del l[0]   
    >>> l   
    [456, 'abc', 'def', 'ghi']   
    >>> del l[2:]   
    >>> l   
    [456, 'abc']   

 

 (4)一些有趣的用法(来自论坛 id—咖啡舞者

   去掉列表中每个元素头尾的空格

  代码
    >>> freshfruit = [' banana', ' loganberry ', 'passion fruit ']    
    >>> [str.strip() for str in freshfruit]    
    ['banana', 'loganberry', 'passion fruit']  

 

    把列表中,大于3的元素,乘以2:

   代码
    >>> vec = [2, 4, 6]    
    >>> [2*x for x in vec if x > 3]    
    [8, 12]   



    把列表1的每一个元素和列表2的每一个元素相乘:

   代码
   >>> lst1 = [2, 4, 6]    
    >>> lst2 = [4, 3, -9]    
    >>> [x*y for x in lst1 for y in lst2]    
    [8, 6, -18, 16, 12, -36, 24, 18, -54]  

 

    取获[0-10)的平方:

   代码
  1. [x**2 for x in range(10)] 


 3 字典

     Python里的字典就像C++里的map,以键值对的方式存在并操作,其特点如下

  • 通过键来存取,而非偏移量;
  • 键值对是无序的;
  • 键和值可以是任意对象;
  • 长度可变,任意嵌套;
  • 在字典里,不能再有序列操作,虽然字典在某些方面与列表类似,但不要把列表套在字典上

 (1) 基本操作

   代码
    >>> table = {'abc':1, 'def':2, 'ghi':3}   
    >>> table['abc']   
    1   
    >>> len(table)   
    3   
    >>> table.keys()   
    ['abc', 'ghi', 'def']   
    >>> table.values()   
    [1, 3, 2]   
    >>> table.has_key('def')   
    True  
    >>> table.items()   
    [('abc', 1), ('ghi', 3), ('def', 2)] 


 (2) 修改,删除,添加

   代码
    >>> table = {'abc':1, 'def':2, 'ghi':3}   
    >>> table['ghi'] = ('g', 'h', 'i')   
    >>> table   
    {'abc': 1, 'ghi': ('g', 'h', 'i'), 'def': 2}   
    >>> del table['abc']   
    >>> table   
    {'ghi': ('g', 'h', 'i'), 'def': 2}   
    >>> table['xyz'] = ['x', 'y', 'z']   
    >>> table   
    {'xyz': ['x', 'y', 'z'], 'ghi': ('g', 'h', 'i'), 'def': 2}



 

      在这里需要来一句,对于字典的扩充,只需定义一个新的键值对即可,而对于列表,就只能用append方法或分片赋值。

 (3)对字典的遍历

  代码
    >>> table = {'abc':1, 'def':2, 'ghi':3}   
    >>> for key in table.keys():   
        print key, '\t', table[key]   
                 
    abc     1   
    ghi     3   
    def     2   
 

4 文件

   与C++的File类相比,Python的文件类要狭义一些

 (1) 文件写

   代码
    >>> myfile = open('myfile', 'w')   
    >>> myfile.write('hello world\n')   
    >>> myfile.close()   

 

     Python的一个open语句就打开了一个文件(当给定的文件不存在时,会自动建立一个新的文件)。open的第一个参数是文件名,第二个参数是操作模式,所谓操作模式就是你打开一个文件是用来干什么的,是读,还是写(当然操作模式不仅只有读和写)。还有一件事,操作完要记得关。

  (2) 文件读

   代码
    >>> myfile = open('myfile', 'r')   
    >>> myfile.readlinereadline()   
    'hello world\n'   



目录
打赏
0
0
0
0
15
分享
相关文章
解锁文件共享软件背后基于 Python 的二叉搜索树算法密码
文件共享软件在数字化时代扮演着连接全球用户、促进知识与数据交流的重要角色。二叉搜索树作为一种高效的数据结构,通过有序存储和快速检索文件,极大提升了文件共享平台的性能。它依据文件名或时间戳等关键属性排序,支持高效插入、删除和查找操作,显著优化用户体验。本文还展示了用Python实现的简单二叉搜索树代码,帮助理解其工作原理,并展望了该算法在分布式计算和机器学习领域的未来应用前景。
深入探讨 Python 列表与元组:操作技巧、性能特性与适用场景
Python 列表和元组是两种强大且常用的数据结构,各自具有独特的特性和适用场景。通过对它们的深入理解和熟练应用,可以显著提高编程效率和代码质量。无论是在数据处理、函数参数传递还是多线程环境中,合理选择和使用列表与元组都能够使得代码更加简洁、高效和安全。
29 9
Python中的Paramiko与FTP文件夹及文件检测技巧
通过使用 Paramiko 和 FTP 库,开发者可以方便地检测远程服务器上的文件和文件夹是否存在。Paramiko 提供了通过 SSH 协议进行远程文件管理的能力,而 `ftplib` 则提供了通过 FTP 协议进行文件传输和管理的功能。通过理解和应用这些工具,您可以更加高效地管理和监控远程服务器上的文件系统。
59 20
[oeasy]python069_当前作用域都有些什么_列表dir_函数_builtins
本文介绍了Python中`dir()`函数的使用方法及其作用。`dir()`可以列出当前作用域内的所有变量和成员,类似于`locals()`,但`dir()`不仅限于本地变量,还能显示模块中的所有成员。通过`dir(__builtins__)`可以查看内建模块中的所有内建函数,如`print`、`ord`、`chr`等。此外,还回顾了`try-except-finally`结构在数据库连接中的应用,并解释了为何`print`函数可以直接使用而无需导入,因为它位于`__builtins__`模块中。最后,简要提及了删除`__builtins__.print`的方法及其影响。
24 0
如何在Python中高效地读写大型文件?
大家好,我是V哥。上一篇介绍了Python文件读写操作,今天聊聊如何高效处理大型文件。主要方法包括:逐行读取、分块读取、内存映射(mmap)、pandas分块处理CSV、numpy处理二进制文件、itertools迭代处理及linecache逐行读取。这些方法能有效节省内存,提升效率。关注威哥爱编程,学习更多Python技巧。
如何使用 Python 进行文件读写操作?
大家好,我是V哥。本文介绍Python中文件读写操作的方法,包括文件读取、写入、追加、二进制模式、JSON、CSV和Pandas模块的使用,以及对象序列化与反序列化。通过这些方法,你可以根据不同的文件类型和需求,灵活选择合适的方式进行操作。希望对正在学习Python的小伙伴们有所帮助。欢迎关注威哥爱编程,全栈路上我们并肩前行。
剖析文件共享工具背后的Python哈希表算法奥秘
在数字化时代,文件共享工具不可或缺。哈希表算法通过将文件名或哈希值映射到存储位置,实现快速检索与高效管理。Python中的哈希表可用于创建简易文件索引,支持快速插入和查找文件路径。哈希表不仅提升了文件定位速度,还优化了存储管理和多节点数据一致性,确保文件共享工具高效运行,满足多用户并发需求,推动文件共享领域向更高效、便捷的方向发展。
|
3月前
|
Python列表
Python列表。
63 8
Python基础 | 深浅拷贝问题、递归函数练习
在实际工作中,经常涉及到数据的传递,在数据传递使用过程中,可能会发生数据被修改的问题。为了防止数据被修改,就需要在传递一个副本,即使副本被修改,也不会影响原数据的使用。为了生成这个副本,就产生了拷贝。下面先了解一下几个概念:对象、可变类型、引用
282 0
Python基础 | 深浅拷贝问题、递归函数练习
python——基础练习(五)
python——基础练习(五)
147 0
python——基础练习(五)

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等