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']
로그인 후 복사를 삽입하고
추가 목록 2 전체를 목록 1에 요소로 추가합니다.
languages.append(["Ruby", "PHP"]) languages
['Python', 'C', 'C++', 'R', 'Java', ['Ruby', 'PHP']]
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 'tuple'>
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'
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'
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'
字典的性质
字典的长度——键值对的个数
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











PHP와 Python은 각각 고유 한 장점이 있으며 프로젝트 요구 사항에 따라 선택합니다. 1.PHP는 웹 개발, 특히 웹 사이트의 빠른 개발 및 유지 보수에 적합합니다. 2. Python은 간결한 구문을 가진 데이터 과학, 기계 학습 및 인공 지능에 적합하며 초보자에게 적합합니다.

Python은 게임 및 GUI 개발에서 탁월합니다. 1) 게임 개발은 Pygame을 사용하여 드로잉, 오디오 및 기타 기능을 제공하며 2D 게임을 만드는 데 적합합니다. 2) GUI 개발은 Tkinter 또는 PYQT를 선택할 수 있습니다. Tkinter는 간단하고 사용하기 쉽고 PYQT는 풍부한 기능을 가지고 있으며 전문 개발에 적합합니다.

데비안 시스템의 readdir 함수는 디렉토리 컨텐츠를 읽는 데 사용되는 시스템 호출이며 종종 C 프로그래밍에 사용됩니다. 이 기사에서는 ReadDir를 다른 도구와 통합하여 기능을 향상시키는 방법을 설명합니다. 방법 1 : C 언어 프로그램을 파이프 라인과 결합하고 먼저 C 프로그램을 작성하여 readDir 함수를 호출하고 결과를 출력하십시오.#포함#포함#포함#포함#includinTmain (intargc, char*argv []) {dir*dir; structdirent*entry; if (argc! = 2) {

제한된 시간에 Python 학습 효율을 극대화하려면 Python의 DateTime, Time 및 Schedule 모듈을 사용할 수 있습니다. 1. DateTime 모듈은 학습 시간을 기록하고 계획하는 데 사용됩니다. 2. 시간 모듈은 학습과 휴식 시간을 설정하는 데 도움이됩니다. 3. 일정 모듈은 주간 학습 작업을 자동으로 배열합니다.

이 기사에서는 Debian 시스템에서 NginxSSL 인증서를 업데이트하는 방법에 대해 안내합니다. 1 단계 : CertBot을 먼저 설치하십시오. 시스템에 CERTBOT 및 PYTHON3-CERTBOT-NGINX 패키지가 설치되어 있는지 확인하십시오. 설치되지 않은 경우 다음 명령을 실행하십시오. sudoapt-getupdatesudoapt-getinstallcertbotpython3-certbot-nginx 2 단계 : 인증서 획득 및 구성 rectbot 명령을 사용하여 nginx를 획득하고 nginx를 구성하십시오.

데비안 시스템에서 HTTPS 서버를 구성하려면 필요한 소프트웨어 설치, SSL 인증서 생성 및 SSL 인증서를 사용하기 위해 웹 서버 (예 : Apache 또는 Nginx)를 구성하는 등 여러 단계가 포함됩니다. 다음은 Apacheweb 서버를 사용하고 있다고 가정하는 기본 안내서입니다. 1. 필요한 소프트웨어를 먼저 설치하고 시스템이 최신 상태인지 확인하고 Apache 및 OpenSSL을 설치하십시오 : Sudoaptupdatesudoaptupgradesudoaptinsta

데비안에서 gitlab 플러그인을 개발하려면 몇 가지 특정 단계와 지식이 필요합니다. 다음은이 과정을 시작하는 데 도움이되는 기본 안내서입니다. Gitlab을 먼저 설치하려면 Debian 시스템에 Gitlab을 설치해야합니다. Gitlab의 공식 설치 매뉴얼을 참조 할 수 있습니다. API 액세스 토큰을 얻으십시오 API 통합을 수행하기 전에 Gitlab의 API 액세스 토큰을 먼저 가져와야합니다. Gitlab 대시 보드를 열고 사용자 설정에서 "AccessTokens"옵션을 찾은 다음 새 액세스 토큰을 생성하십시오. 생성됩니다

아파치는 인터넷 뒤의 영웅입니다. 웹 서버 일뿐 만 아니라 큰 트래픽을 지원하고 동적 콘텐츠를 제공하는 강력한 플랫폼이기도합니다. 모듈 식 설계를 통해 매우 높은 유연성을 제공하여 필요에 따라 다양한 기능을 확장 할 수 있습니다. 그러나 Modularity는 또한 신중한 관리가 필요한 구성 및 성능 문제를 제시합니다. Apache는 사용자 정의가 필요한 서버 시나리오에 적합하고 복잡한 요구를 충족시킵니다.
