찾다
백엔드 개발파이썬 튜토리얼Python의 결합된 데이터 유형을 사용하는 방법

결합 데이터 유형

1 리스트

리스트의 표현
  • 순차 유형: 내부 요소는 위치 관계를 가지며 위치 번호를 통해 요소에 접근할 수 있습니다.

  • 리스트는 여러 유형의 데이터를 사용할 수 있는 목록입니다. 요소 및 지원 요소 추가, 삭제, 검색 및 수정 작업을 위한 시퀀스 유형

ls = ["Python", 1989, True, {"version": 3.7}]
ls
['Python', 1989, True, {'version': 3.7}]
  • 또 다른 생성 방법: 목록(반복 가능한 객체)

  • 반복 가능한 객체에는 문자열, 튜플, 세트, ​​범위()가 포함됩니다. 잠깐

목록에 넣을 문자열

list("欢迎订阅本专栏")
['欢', '迎', '订', '阅', '本', '专', '栏']

튜플을 목록에 추가

list(("我", "们", "很", "像"))
['我', '们', '很', '像']

목록에 설정

list({"李雷", "韩梅梅", "Jim", "Green"})
['Green', 'Jim', '李雷', '韩梅梅']

특수 범위()

for i in [0, 1, 2, 3, 4, 5]:
    print(i)
0
1
2
3
4
5
for i in range(6):
    print(i)
0
1
2
3
4
5
  • range(시작 번호, 정지 번호, 번호 간격 )

시작번호가 기본값인 경우 기본값은 0

정지번호가 반드시 포함되어야 하는데 정차번호를 알 수 없으니 주의하세요

번호간격은 기본으로 되어있습니다. is 1

for i in range(1, 11, 2):
    print(i)
1
3
5
7
9
  • range() to list

list(range(1, 11, 2))
[1, 3, 5, 7, 9]

목록의 특성

  • 목록의 길이 - len(목록)

ls = [1, 2, 3, 4, 5]
len(ls)
5
  • 인덱스 목록 - 동일한 시퀀스 유형 문자열은 완전히 동일합니다.

변수 이름 [위치 번호]

순방향 인덱스는 0부터 시작
역방향 인덱스는 -1부터 시작

cars = ["BYD", "BMW", "AUDI", "TOYOTA"]
print(cars[0])
print(cars[-4])
BYD
BYD
  • 목록의 조각

변수 이름 [시작 위치: 끝 위치: 슬라이스 간격]

cars = ["BYD", "BMW", "AUDI", "TOYOTA"]
  • forward Slice

print(cars[:3])     # 前三个元素,开始位置缺省,默认为0;切片间隔缺省,默认为1
['BYD', 'BMW', 'AUDI']
print(cars[1:4:2])  # 第二个到第四个元素 前后索引差为2
['BMW', 'TOYOTA']
print(cars[:])      # 获取整个列表,结束位置缺省,默认取值到最后
['BYD', 'BMW', 'AUDI', 'TOYOTA']
print(cars[-4:-2])  # 获取前两个元素
['BYD', 'BMW']
  • reverse Slice

cars = ["BYD", "BMW", "AUDI", "TOYOTA"]
print(cars[:-4:-1])      # 开始位置缺省,默认为-1
print(cars[::-1])        # 获得反向列表
['TOYOTA', 'AUDI', 'BMW']
['TOYOTA', 'AUDI', 'BMW', 'BYD']
목록의 연산자
  • ** list1+ 사용 lis2 * * 형식은 목록의 접합을 실현합니다

a = [1, 2]
b = [3, 4]
a+b            # 该用法用的不多
[1, 2, 3, 4]
  •  n*list  또는  list*n 를 사용하여 목록의 이중 복사를 실현합니다

목록 초기화 방법

[0]*10
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
목록 조작 방법

1. 요소 추가

  • 끝에 요소 추가 - list.append(추가할 요소)

languages = ["Python", "C++", "R"]
languages.append("Java")
languages
['Python', 'C++', 'R', 'Java']
  • Insert 임의 위치의 요소 - list.insert(위치 번호, 추가할 요소)
    위치 번호

    의 해당 요소
  • 앞에 추가할 요소
  • languages.insert(1, "C")
    languages
    ['Python', 'C', 'C++', 'R', 'Java']

  • 를 삽입하고

에서 다른 목록으로 병합합니다. end - 목록 1. 확장(목록 2)

추가 목록 2 전체를 목록 1에 요소로 추가합니다.

languages.append(["Ruby", "PHP"])
languages
['Python', 'C', 'C++', 'R', 'Java', ['Ruby', 'PHP']]
extend는 목록 2의 요소를 목록 1에 하나씩 추가합니다. 물론 그럴 수도 있습니다. 추가하여 구현합니다.
    languages = ['Python', 'C', 'C++', 'R', 'Java']
    languages.extend(["Ruby", "PHP"])
    languages
    ['Python', 'C', 'C++', 'R', 'Java', 'Ruby', 'PHP']
  • 2. 요소 삭제

    • 목록의 i 위치에 있는 요소 삭제 list.pop(position)

    languages = ['Python', 'C', 'C++', 'R', 'Java']
    languages.pop(1)
    languages
    ['Python', 'C++', 'R', 'Java']
    • 기본적으로 마지막 요소 삭제

    languages.pop()
    languages
    ['Python', 'C++', 'R']

    목록에 나타나는 삭제할 첫 번째 요소 삭제 List.remove(삭제할 요소)

      languages = ['Python', 'C', 'R', 'C', 'Java']
      languages.remove("C")    
      languages
      ['Python', 'R', 'C', 'Java']
      languages = ['Python', 'C', 'R', 'C', 'Java']
      while "C" in languages:
          languages.remove("C")    
      languages
      ['Python', 'R', 'Java']
    • 3 요소를 찾습니다

    • 요소의 위치입니다. List.index(확인할 요소)

        languages = ['Python', 'C', 'R','Java']
        idx = languages.index("R") 
        idx
        2
      • 4. 요소 수정

        🎜🎜🎜🎜"먼저 색인을 지정한 다음 값을 할당하는" 방법을 사용하여 요소를 수정하세요  목록 이름[위치] = 새 값🎜
      • languages = ['Python', 'C', 'R','Java']
        languages[1] = "C++"
        languages
        ['Python', 'C++', 'R', 'Java']

        5、列表的复制

        • 错误的方式:这种方式仅是相当于给列表起了一个别名

        languages = ['Python', 'C', 'R','Java']
        languages_2 = languages
        print(languages_2)
        ['Python', 'C', 'R', 'Java']
        languages.pop()
        print(languages)
        print(languages_2)
        ['Python', 'C', 'R']
        ['Python', 'C', 'R']
        • 正确的方式——浅拷贝

        当内容中也有列表这种可变的情况时,这时浅拷贝可能出问题,应该采用深拷贝。

        • 方法1:列表.copy()

        languages = ['Python', 'C', 'R','Java']
        languages_2 = languages.copy()
        languages.pop()
        print(languages)
        print(languages_2)
        ['Python', 'C', 'R']
        ['Python', 'C', 'R', 'Java']
        • 方法2:列表 [ : ]

        • 相当于对整个列表的切片

        languages = ['Python', 'C', 'R','Java']
        languages_3 = languages[:]
        languages.pop()
        print(languages)
        print(languages_3)
        ['Python', 'C', 'R']
        ['Python', 'C', 'R', 'Java']

        6、列表的排序

        • 使用列表.sort()对列表进行永久排序

        • 直接在列表上进行操作,无返回值

        • 默认是递增的排序

        ls = [2, 5, 2, 8, 19, 3, 7]
        ls.sort()
        ls
        [2, 2, 3, 5, 7, 8, 19]
        • 递减排列

        ls.sort(reverse = True)
        ls
        [19, 8, 7, 5, 3, 2, 2]
        • 使用sorted(列表)对列表进行临时排序

        • 原列表保持不变,返回排序后的列表

        ls = [2, 5, 2, 8, 19, 3, 7]
        ls_2 = sorted(ls)
        print(ls)
        print(ls_2)
        [2, 5, 2, 8, 19, 3, 7]
        [19, 8, 7, 5, 3, 2, 2]
        sorted(ls, reverse = True)
        [19, 8, 7, 5, 3, 2, 2]

        7、列表的翻转

        • 使用列表.reverse()对列表进行永久翻转

        • 直接在列表上进行操作,无返回值

        ls = [1, 2, 3, 4, 5]
        print(ls[::-1])
        ls
        [5, 4, 3, 2, 1]
        
        [1, 2, 3, 4, 5]
        ls.reverse()
        ls
        [5, 4, 3, 2, 1]

        8、使用for循环对列表进行遍历

        ls = [1, 2, 3, 4, 5]
        for i in ls:
            print(i)
        1
        2
        3
        4
        5

        2 元组

         元组的表达
        • 元组是一个可以使用多种类型元素,一旦定义,内部元素不支持增、删和修改操作的序列类型

        通俗的讲,可以将元组视作“不可变的列表”

        names = ("Peter", "Pual", "Mary")
        元组的操作
        • 不支持元素增加、元素删除、元素修改操作

        • 其他操作与列表的操作完全一致

        元组的常见用处

        打包与解包

        • 例1 返回值是打包成元组的形式

        def f1(x):              # 返回x的平方和立方
            return x**2, x**3   # 实现打包返回
        
        print(f1(3))
        print(type(f1(3)))      # 元组类型
        (9, 27)
        <class></class>
        a, b = f1(3)            # 实现解包赋值 
        print(a)
        print(b)
        9
        27
        • 例2

        • 采用zip函数进行打包

        numbers = [201901, 201902, 201903]
        name = ["小明", "小红", "小强"]
        list(zip(numbers,name))
        [(201901, '小明'), (201902, '小红'), (201903, '小强')]
        for number,name in zip(numbers,name):   # 每次取到一个元组,立刻进行解包赋值
            print(number, name)
        201901 小明
        201902 小红
        201903 小强

        3 字典

        字典的表达
        • 映射类型: 通过“键”-“值”的映射实现数据存储和查找

        • 常规的字典是无序的,仅可以通过键来对数据进行访问

        students = {201901: '小明', 201902: '小红', 201903: '小强'}
        students

        字典键的要求

        • 1、字典的键不能重复

        如果重复,前面的键就被覆盖了

        students = {201901: '小明', 201901: '小红', 201903: '小强'}
        students
        {201901: '小红', 201903: '小强'}
        • 2、字典的键必须是不可变类型,如果键可变,就找不到对应存储的值了

        • 不可变类型:数字、字符串、元组。  一旦确定,它自己就是它自己,变了就不是它了。

        • 可变类型:列表、字典、集合。  一旦确定,还可以随意增删改。因此这三个类型不能作为字典的键。

        d1 = {1: 3}
        d2 = {"s": 3}
        d3 = {(1,2,3): 3}

        上面没有报错,说明是合法的。

        d = {[1, 2]: 3}
        ---------------------------------------------------------------------------
        
        TypeError                                 Traceback (most recent call last)
        
        <ipython-input-68-bf7f06622b3f> in <module>
        ----> 1 d = {[1, 2]: 3}
        
        
        TypeError: unhashable type: 'list'</module></ipython-input-68-bf7f06622b3f>
        d = {{1:2}: 3}
        ---------------------------------------------------------------------------
        
        TypeError                                 Traceback (most recent call last)
        
        <ipython-input-69-188e5512b5fe> in <module>
        ----> 1 d = {{1:2}: 3}
        
        
        TypeError: unhashable type: 'dict'</module></ipython-input-69-188e5512b5fe>
        d = {{1, 2}: 3}
        ---------------------------------------------------------------------------
        
        TypeError                                 Traceback (most recent call last)
        
        <ipython-input-70-c2dfafc1018a> in <module>
        ----> 1 d = {{1, 2}: 3}
        
        
        TypeError: unhashable type: 'set'</module></ipython-input-70-c2dfafc1018a>
        字典的性质
        • 字典的长度——键值对的个数

        students = {201901: '小明', 201902: '小红', 201903: '小强'}
        len(students)
        3
        • 字典的索引

        通过 字典[键] 的形式来获取对应的值

        students = {201901: '小明', 201902: '小红', 201903: '小强'}
        students[201902]
        '小红'
        字典的操作方法

        1、增加键值对

        • 变量名[新键] = 新值

        students = {201901: '小明', 201902: '小红', 201903: '小强'}
        students[201904] = "小雪"
        students
        {201901: '小明', 201902: '小红', 201903: '小强', 201904: '小雪'}

        2、删除键值对

        • 通过del 变量名[待删除键]

        students = {201901: '小明', 201902: '小红', 201903: '小强'}
        del students[201903]
        students
        {201901: '小明', 201902: '小红'}
        • 通过变量名.pop(待删除键)

        students = {201901: '小明', 201902: '小红', 201903: '小强'}
        value = students.pop(201903)   # 删除键值对,同时获得删除键值对的值
        print(value)
        print(students)
        小强
        {201901: '小明', 201902: '小红'}
        • 变量名.popitem() 随机删除一个键值对,并以元组返回删除键值对

        students = {201901: '小明', 201902: '小红', 201903: '小强'}
        key, value = students.popitem()
        print(key, value)
        print(students)
        201903 小强
        {201901: '小明', 201902: '小红'}

        3、修改值

        • 通过先索引后赋值的方式对相应的值进行修改

        students = {201901: '小明', 201902: '小红', 201903: '小强'}
        students[201902] = "小雪"
        students
        {201901: '小明', 201902: '小雪', 201903: '小强'}

        4、d.get( )方法

        d.get(key,default) 从字典d中获取键key对应的值,如果没有这个键,则返回default

        • 小例子:统计"牛奶奶找刘奶奶买牛奶"中字符的出现频率

        s = "牛奶奶找刘奶奶买牛奶"
        d = {}
        print(d)
        for i in s:
            d[i] = d.get(i, 0)+1 # 如果该字符第一次出现,则返回default 0 ,然后+1统计。如果之前就有i这个键,则返回该 key i 所对应的值。
            print(d)
        # print(d)
        {}
        {'牛': 1}
        {'牛': 1, '奶': 1}
        {'牛': 1, '奶': 2}
        {'牛': 1, '奶': 2, '找': 1}
        {'牛': 1, '奶': 2, '找': 1, '刘': 1}
        {'牛': 1, '奶': 3, '找': 1, '刘': 1}
        {'牛': 1, '奶': 4, '找': 1, '刘': 1}
        {'牛': 1, '奶': 4, '找': 1, '刘': 1, '买': 1}
        {'牛': 2, '奶': 4, '找': 1, '刘': 1, '买': 1}
        {'牛': 2, '奶': 5, '找': 1, '刘': 1, '买': 1}

        5、d.keys( ) d.values( )方法

        把所有的key,value 单独拿出来。

        students = {201901: '小明', 201902: '小红', 201903: '小强'}
        print(list(students.keys()))
        print(list(students.values()))
        [201901, 201902, 201903]
        ['小明', '小红', '小强']

        6、d.items( )方法及字典的遍历

        print(list(students.items()))
        for k, v in students.items():#进行解包
            print(k, v)
        [(201901, '小明'), (201902, '小红'), (201903, '小强')]
        201901 小明
        201902 小红
        201903 小强

        4 集合

        集合的表达

        • 一系列互不相等元素的无序集合(互斥)

        • 元素必须是不可变类型:数字,字符串或元组,可视作字典的键

        • 可以看做是没有值,或者值为None的字典

        students = {"小明", "小红", "小强", "小明"}   #可用于去重
        students
        {'小强', '小明', '小红'}
        集合的运算
        • 小例子 通过集合进行交集并集的运算

        Chinese_A = {"刘德华", "张学友", "张曼玉", "钟楚红", "古天乐", "林青霞"}
        Chinese_A
        {'刘德华', '古天乐', '张学友', '张曼玉', '林青霞', '钟楚红'}
        Math_A = {"林青霞", "郭富城", "王祖贤", "刘德华", "张曼玉", "黎明"}
        Math_A
        {'刘德华', '张曼玉', '林青霞', '王祖贤', '郭富城', '黎明'}
        • 语文和数学两门均为A的学员

        • S & T 返回一个新集合,包括同时在集合S和T中的元素

        Chinese_A & Math_A
        {'刘德华', '张曼玉', '林青霞'}
        • 语文或数学至少一门为A的学员

        • S | T 返回一个新集合,包括集合S和T中的所有元素

        Chinese_A | Math_A
        {'刘德华', '古天乐', '张学友', '张曼玉', '林青霞', '王祖贤', '郭富城', '钟楚红', '黎明'}
        • 语文数学只有一门为A的学员

        • S ^ T 返回一个新集合,包括集合S和T中的非共同元素

        Chinese_A ^ Math_A
        {'古天乐', '张学友', '王祖贤', '郭富城', '钟楚红', '黎明'}
        • 语文为A,数学不为A的学员

        • S - T 返回一个新集合,包括在集合S但不在集合T中的元素

        Chinese_A - Math_A
        {'古天乐', '张学友', '钟楚红'}
        • 数学为A,语文不为A的学员

        Math_A - Chinese_A
        {'王祖贤', '郭富城', '黎明'}
         集合的操作方法
        • 增加元素——S.add(x)

        stars = {"刘德华", "张学友", "张曼玉"}
        stars.add("王祖贤")
        stars
        {'刘德华', '张学友', '张曼玉', '王祖贤'}
        • 移除元素——S.remove(x)

        stars.remove("王祖贤")
        stars
        {'刘德华', '张学友', '张曼玉'}
        • 集合的长度——len(S)

        len(stars)
        3
        • 集合的遍历——借助for循环

        for star in stars:
            print(star)
        张学友
        张曼玉
        刘德华

        위 내용은 Python의 결합된 데이터 유형을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

        성명
        이 기사는 亿速云에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
        Numpy를 사용하여 다차원 배열을 어떻게 생성합니까?Numpy를 사용하여 다차원 배열을 어떻게 생성합니까?Apr 29, 2025 am 12:27 AM

        다음 단계를 통해 Numpy를 사용하여 다차원 배열을 만들 수 있습니다. 1) Numpy.array () 함수를 사용하여 NP.Array ([[1,2,3], [4,5,6]]과 같은 배열을 생성하여 2D 배열을 만듭니다. 2) np.zeros (), np.ones (), np.random.random () 및 기타 함수를 사용하여 특정 값으로 채워진 배열을 만듭니다. 3) 서브 어레이의 길이가 일관되고 오류를 피하기 위해 배열의 모양과 크기 특성을 이해하십시오. 4) NP.Reshape () 함수를 사용하여 배열의 모양을 변경하십시오. 5) 코드가 명확하고 효율적인지 확인하기 위해 메모리 사용에주의를 기울이십시오.

        Numpy 어레이에서 '방송'의 개념을 설명하십시오.Numpy 어레이에서 '방송'의 개념을 설명하십시오.Apr 29, 2025 am 12:23 AM

        BroadcastingInnumpyIsamethodtoperformoperationsonArraysoffferentShapesByAutomicallyAligningThem.itsimplifiesCode, enourseadability, andboostsperformance.here'showitworks : 1) smalraysarepaddedwithonestomatchdimenseare

        데이터 저장을 위해 목록, Array.Array 및 Numpy Array 중에서 선택하는 방법을 설명하십시오.데이터 저장을 위해 목록, Array.Array 및 Numpy Array 중에서 선택하는 방법을 설명하십시오.Apr 29, 2025 am 12:20 AM

        forpythondatastorage, chooselistsforflexibilitywithmixeddatatypes, array.arrayformemory-effic homogeneousnumericaldata, andnumpyarraysforadvancednumericalcomputing.listsareversatilebutlessefficipforlargenumericaldatasets.arrayoffersamiddlegro

        파이썬 목록을 사용하는 것이 배열을 사용하는 것보다 더 적절한 시나리오의 예를 제시하십시오.파이썬 목록을 사용하는 것이 배열을 사용하는 것보다 더 적절한 시나리오의 예를 제시하십시오.Apr 29, 2025 am 12:17 AM

        pythonlistsarebetterthanarraysformanagingDiversEdatatypes.1) 1) listscanholdementsofdifferentTypes, 2) thearedynamic, weantEasyAdditionSandremovals, 3) wefferintufiveOperationsLikEslicing, but 4) butiendess-effectorlowerggatesets.

        파이썬 어레이에서 요소에 어떻게 액세스합니까?파이썬 어레이에서 요소에 어떻게 액세스합니까?Apr 29, 2025 am 12:11 AM

        toaccesselementsInapyThonArray : my_array [2] AccessHetHirdElement, returning3.pythonuseszero 기반 인덱싱 .1) 사용 positiveAndnegativeIndexing : my_list [0] forthefirstelement, my_list [-1] forstelast.2) audeeliciforarange : my_list

        파이썬에서 튜플 이해력이 가능합니까? 그렇다면, 어떻게 그리고 그렇지 않다면?파이썬에서 튜플 이해력이 가능합니까? 그렇다면, 어떻게 그리고 그렇지 않다면?Apr 28, 2025 pm 04:34 PM

        기사는 구문 모호성으로 인해 파이썬에서 튜플 이해의 불가능성에 대해 논의합니다. 튜플을 효율적으로 생성하기 위해 튜플 ()을 사용하는 것과 같은 대안이 제안됩니다. (159 자)

        파이썬의 모듈과 패키지는 무엇입니까?파이썬의 모듈과 패키지는 무엇입니까?Apr 28, 2025 pm 04:33 PM

        이 기사는 파이썬의 모듈과 패키지, 차이점 및 사용법을 설명합니다. 모듈은 단일 파일이고 패키지는 __init__.py 파일이있는 디렉토리이며 관련 모듈을 계층 적으로 구성합니다.

        파이썬에서 Docstring이란 무엇입니까?파이썬에서 Docstring이란 무엇입니까?Apr 28, 2025 pm 04:30 PM

        기사는 Python의 Docstrings, 사용법 및 혜택에 대해 설명합니다. 주요 이슈 : 코드 문서 및 접근성에 대한 문서의 중요성.

        See all articles

        핫 AI 도구

        Undresser.AI Undress

        Undresser.AI Undress

        사실적인 누드 사진을 만들기 위한 AI 기반 앱

        AI Clothes Remover

        AI Clothes Remover

        사진에서 옷을 제거하는 온라인 AI 도구입니다.

        Undress AI Tool

        Undress AI Tool

        무료로 이미지를 벗다

        Clothoff.io

        Clothoff.io

        AI 옷 제거제

        Video Face Swap

        Video Face Swap

        완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

        뜨거운 도구

        MinGW - Windows용 미니멀리스트 GNU

        MinGW - Windows용 미니멀리스트 GNU

        이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

        SublimeText3 영어 버전

        SublimeText3 영어 버전

        권장 사항: Win 버전, 코드 프롬프트 지원!

        SublimeText3 Linux 새 버전

        SublimeText3 Linux 새 버전

        SublimeText3 Linux 최신 버전

        SublimeText3 Mac 버전

        SublimeText3 Mac 버전

        신 수준의 코드 편집 소프트웨어(SublimeText3)

        Atom Editor Mac 버전 다운로드

        Atom Editor Mac 버전 다운로드

        가장 인기 있는 오픈 소스 편집기