Python의 기본 데이터 유형은 무엇이며 이를 사용하는 방법
1부 숫자 유형
1.1 숫자 유형의 구성
1.1.1 정수 - 다양한 기본 시스템의 변환
기본 입력은 10진수
2진수 0b, 8진수 0o, 16진수 0x
- 십진수와 다른 진수의 변환
-
16 == 0b10000 == 0o20 == 0x10
로그인 후 복사True
로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사
a = bin(16) # 转二进制
b = oct(16) # 转八进制
c = hex(16) # 转十六进制
print(a, b, c)
0b10000 0o20 0x10
a == b == c
False
- 다른 진수로의 변환 십진수
-
type(a)
로그인 후 복사str
로그인 후 복사1.1.2 부동 소수점 수 - 불확실성
- 불확실한 십진수 문제
-
d = int(a, 2) # 二进制转十进制 e = int(b, 8) # 八进制转十进制 f = int(c, 16) # 十六进制转十进制 print(d, e, f)
로그인 후 복사16 16 16
로그인 후 복사(0.1+0.2) == 0.3
로그인 후 복사False
로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사
- 원인: 부분 소수점은 불가능합니다. 완전히 이진 소수로 표현되어야 합니다
-
0.1+0.2
로그인 후 복사0.00011001100110011001 0.09999942779541016
0.0011001100110011 0.1999969482421875
0.01001100110011001 0.29999542236328125
0.01100110011001101 0.40000152587890625
소수점 이하 1자리 )
0.30000000000000004
二进制 十进制
0.1 + 0.7
0.7999999999999999
- 1.1.3 복소수 - a+bj
- 대문자 J 또는 소문자 j 사용 가능
-
a = 3*0.1 print(a)
로그인 후 복사0.30000000000000004
로그인 후 복사로그인 후 복사허수부 계수가 1인 경우 적어주셔야 합니다. 명시적으로 -
b = round(a, 1) print(b) b == 0.3
로그인 후 복사 1.2 숫자 연산 연산자(연산자 b)
- 덧셈, 뺄셈, 곱셈 및 나눗셈 연산 + - /
- 정수 몫//및 모듈러 연산%
0.3 True
3+4j 2+5J
(2+5j)
- 몇 가지 참고 사항
- 나누기 연산의 결과는 부동 소수점 숫자입니다.
2+1j
(1+3-4*2)/5
-0.8
x = 1 -x
-1
2**3
- 절댓값 찾기 abs()
8
13//5 # 整数商 x/y 向下取整数
2
13 % 5 # 模运算 余数 13=2*5+3
- 모듈로 마력으로 계산된 전력 (x,n,m)
1+1.5
2.5
2/5
0.4
round(x,n)
8/4
2.0
abs(-5)
5
abs(3+4j) # 对复数a+bj 执行的是求模运算(a^2+b^2)^0.5
5.0
등의 값을 반환합니다. tuple (x//y,x % y)
pow(2, 5) # pow(x,n) x的n次方 等价于x**n
32
-
pow(2, 5, 3) # 2^5 % 3 更快速
로그인 후 복사2
로그인 후 복사로그인 후 복사로그인 후 복사a = 1.618 print(round(a)) # 默认四舍五入为整数
로그인 후 복사2
로그인 후 복사로그인 후 복사로그인 후 복사
- 참고: sum 시퀀스 데이터로 채워야 합니다
print(round(a, 2)) # 参数2表示四舍五入后保留2位小数
1.62
print(round(a, 5)) # 位数不足,无需补齐
1.618
divmod(13, 5) # 较(x//y,x % y)更快,只执行了一次x/y
(2, 3)
- "" 또는 ''를 사용하세요.
max(3, 2, 3, 6, 9, 4, 5)
9
- Single in double
a = [3, 2, 3, 6, 9, 4, 5] print("max:", max(a)) print("min:", min(a))
max: 9 min: 2
Double in Single
print('"Python" is good')
"Python" is good
双中有双,单中有单——转义符 \
# print(""Python" is good") print("\"Python\" is good") # \ 字符
"Python" is good
转义符可以用来换行继续输入
s = "py\ thon" print(s)
python
2.2 字符串的性质
2.2.1 字符串的索引
s = "My name is Peppa Pig"
变量名[位置编号]
正向索引——从零开始递增
位置编号不能超过字符串的长度
空格也是一个位置
print(s[0]) print(s[2]) print(s[5])
M m
s = "My name is Peppa Pig"
反向索引——从-1开始递减
print(s[-1]) print(s[-3]) print(s[-5])
g P a
索引只能获得一个字符,如何获得多个字符?
2.2.2 字符串的切片
变量名[开始位置:结束位置:切片间隔]
切片间隔如不设置默认为1,可省略
切片范围不包含结束位置(前闭后开)
s = "Python" print(s[0:3:1])
Pyt
print(s[0:3])
Pyt
print(s[0:3:2])
Pt
起始位置是0 可以省略
结束位置省略,代表可以取到最后一个字符
可以使用反向索引
s = "Python" print(s[0:6])
Python
print(s[:6])
Python
print(s[:])
Python
print(s[-6:])
Python
反向切片
起始位置是-1也可以省略
结束位置省略,代表可以取到第一个字符
关键点在于-1,代表前一个位置比后一个位置大-1
s = "123456789" print(s[-1:-10:-1])
987654321
print(s[:-10:-1])
987654321
print(s[::-1])
987654321
2.3 字符串操作符
2.3.1 字符串的拼接
字符串1+字符串2
a = "I love " b = "my wife " a+b
'I love my wife '
2.3.2 字符串的成倍复制
字符串 * n n * 字符串
c = a+b print(c*3) print(3*c)
I love my wife I love my wife I love my wife I love my wife I love my wife I love my wife
2.2.3 成员运算
子集in全集 任何一个连续的切片都是原字符串的子集
folk_singers = "Peter, Paul and Mary" "Peter" in folk_singers
True
"PPM" in folk_singers
False
遍历字符串字符 for 字符 in 字符串
for s in "Python": print(s)
P y t h o n
2.4 字符串处理函数
2.4.1 字符串的长度
所含字符的个数
s = "python" len(s)
6
2.4.2 字符编码
将中文字库,英文字母、数字、特殊字符等转化成计算机可识别的二进制数
每个单一字符对应一个唯一的互不重复的二进制编码
Python 中使用的是Unicode编码
将字符转化为Unicode码——ord(字符)
print(ord("1")) print(ord("a")) print(ord("*")) print(ord("中")) print(ord("国"))
49 97 42 20013 22269
将Unicode码转化为字符——chr(Unicode码)
print(chr(1010)) print(chr(10000)) print(chr(12345)) print(chr(23456))
ϲ ✐ 〹 宠
2.5 字符串的处理方法
2.5.1 字符串的分割——字符串.split(分割字符)
返回一个列表
原字符串不变
上述特性适合以下所有字符串处理方法
languages = "Python C C++ Java PHP R" languages_list = languages.split(" ")#括号里的参数就是我们希望对目标字符串进行分割的标记 print(languages_list) print(languages)
['Python', 'C', 'C++', 'Java', 'PHP', 'R'] Python C C++ Java PHP R
2.5.2 字符串的聚合——“聚合字符”.join(可迭代数据类型)
可迭代类型 如:字符串、列表
s = "12345" s_join = ",".join(s) #把可迭代的对象每一个都取出来,相邻两个之间加上聚合字符 s_join
'1,2,3,4,5'
序列类型的元素必须是字符类型
# s = [1, 2, 3, 4, 5] 无法使用聚合 s = ["1", "2", "3", "4", "5"] "*".join(s)
'1*2*3*4*5'
3.5.3 删除两端特定字符——字符串.strip(删除字符)
strip从两侧开始搜索,遇到指定字符执行删除,遇到非指定字符,搜索停止
类似的还有左删除lstrip和右删除rstrip
s = " I have many blanks " print(s.strip(" ")) #从两端进行搜索,遇到指定字符后删除空格,然后停止 print(s.lstrip(" ")) print(s.rstrip(" ")) print(s)
I have many blanks I have many blanks I have many blanks I have many blanks
3.5.4 字符串的替换——字符串.replace("被替换","替换成")
s = "Python is coming" s1 = s.replace("Python","Py") print(s1)
Py is coming
3.5.5 字符串统计——字符串.count("待统计字符串")
s = "Python is an excellent language" print("an:", s.count("an")) print("e:", s.count("e"))
an: 2 e: 4
3.3.6 字符串字母大小写
字符串.upper() 字母全部大写
s = "Python" s.upper()
'PYTHON'
字符串.lower() 字母全部小写
print(s.lower()) print(s)
python Python
字符串.title()首字母大写
s.title()
'Python'
第三部分 布尔类型TRUEorFalse
3.1 逻辑运算的结果
a = 10 print(a > 8) print(a == 12) print(a < 5)
True False False
any() 数据有一个是非零就为True
all() 数据有一个是零就为False (元素都是非零的)
print(any([False,1,0,None])) # 0 False None 都是无 print(all([False,1,0,None]))
True False
3.2 指示条件
n = 2800 while True: m = eval("请输入一个正整数:")) if m == n: print("正确") break elif m > n: print("太大了") else: print("太小了")
请输入一个正整数:280 太小了 请输入一个正整数:2800 正确
3.3 作为numpy数组的掩码
import numpy as np x = np.array([[1, 3, 2, 5, 7]]) # 定义 numpy数组 print(x > 3) x[x > 3]
[[False False False True True]] array([5, 7])
第四部分 类型判别及类型转换
4.1 类型判别
type(变量)
age = 20 name = "Ada" print(type(age)) print(type(name))
<class 'int'> <class 'str'>
isinstance(变量,预判类型) 承认继承
变量类型是预判类型的子类型,则为真,否则为假
print(isinstance(age, int)) # 承认继承 这里的int就相当于是一个类
True
print(isinstance(age, object)) print(isinstance(name, object)) # object 是所有类的老祖宗
True True
字符串检查方法
字符串.isdigit()字符是否只有数字组成
age = "20" name = "Ada"
age.isdigit()
True
name.isdigit()
False
字符串.isalpha()字符是否只有字母组成
name.isalpha()
True
age.isalpha()
False
字符串.isalnum()字符是否只有数字和字母组成
"Ada20".isalnum() # 比如可用于判断用户名是否合法
True
4.2 类型转换
数字类型转字符串 str(数字类型)
age = 20 print("My age is "+str(age))
My age is 20
-
仅有数字组成的字符串转数字 int() float() eval(232, 232, 232); background: rgb(249, 249, 249);">
s1 = "20" s2 = "10.1"
로그인 후 복사
int(s1) # 仅整型 # int(s2) 会错误
20
float(s1)
20.0
float(s2)
10.1
eval(232, 232, 232); background: rgb(249, 249, 249);">20
eval(232, 232, 232); background: rgb(249, 249, 249);">10.1
위 내용은 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)

뜨거운 주제









C 언어에는 내장 합계 기능이 없으므로 직접 작성해야합니다. 합계는 배열 및 축적 요소를 가로 질러 달성 할 수 있습니다. 루프 버전 : 루프 및 배열 길이를 사용하여 계산됩니다. 포인터 버전 : 포인터를 사용하여 배열 요소를 가리키며 효율적인 합계는 자체 증가 포인터를 통해 달성됩니다. 동적으로 배열 버전을 할당 : 배열을 동적으로 할당하고 메모리를 직접 관리하여 메모리 누출을 방지하기 위해 할당 된 메모리가 해제되도록합니다.

기술 및 산업 요구에 따라 Python 및 JavaScript 개발자에 대한 절대 급여는 없습니다. 1. 파이썬은 데이터 과학 및 기계 학습에서 더 많은 비용을 지불 할 수 있습니다. 2. JavaScript는 프론트 엔드 및 풀 스택 개발에 큰 수요가 있으며 급여도 상당합니다. 3. 영향 요인에는 경험, 지리적 위치, 회사 규모 및 특정 기술이 포함됩니다.

구별되고 구별되는 것은 구별과 관련이 있지만, 다르게 사용됩니다. 뚜렷한 (형용사)는 사물 자체의 독창성을 묘사하고 사물 사이의 차이를 강조하는 데 사용됩니다. 뚜렷한 (동사)는 구별 행동이나 능력을 나타내며 차별 과정을 설명하는 데 사용됩니다. 프로그래밍에서 구별은 종종 중복 제거 작업과 같은 컬렉션에서 요소의 독창성을 나타내는 데 사용됩니다. 홀수 및 짝수 숫자를 구별하는 것과 같은 알고리즘이나 함수의 설계에 별개가 반영됩니다. 최적화 할 때 별도의 작업은 적절한 알고리즘 및 데이터 구조를 선택해야하며, 고유 한 작업은 논리 효율성의 구별을 최적화하고 명확하고 읽을 수있는 코드 작성에주의를 기울여야합니다.

! x 이해! x는 C 언어로 된 논리적 비 운영자입니다. 그것은 x의 값, 즉 실제 변경, 거짓, 잘못된 변경 사항을 부수합니다. 그러나 C의 진실과 거짓은 부울 유형보다는 숫자 값으로 표시되며, 0이 아닌 것은 참으로 간주되며 0만이 거짓으로 간주됩니다. 따라서! x는 음수를 양수와 동일하게 처리하며 사실로 간주됩니다.

합에 대한 C에는 내장 합계 기능이 없지만 다음과 같이 구현할 수 있습니다. 루프를 사용하여 요소를 하나씩 축적합니다. 포인터를 사용하여 요소를 하나씩 액세스하고 축적합니다. 큰 데이터 볼륨의 경우 병렬 계산을 고려하십시오.

코드 취약점, 브라우저 호환성, 성능 최적화, 보안 업데이트 및 사용자 경험 개선과 같은 요소로 인해 H5 페이지를 지속적으로 유지해야합니다. 효과적인 유지 관리 방법에는 완전한 테스트 시스템 설정, 버전 제어 도구 사용, 페이지 성능을 정기적으로 모니터링하고 사용자 피드백 수집 및 유지 관리 계획을 수립하는 것이 포함됩니다.

크롤링하는 동안 58.com 작업 페이지의 동적 데이터를 얻는 방법은 무엇입니까? Crawler 도구를 사용하여 58.com의 작업 페이지를 크롤링 할 때는이 문제가 발생할 수 있습니다.

코드 복사 및 붙여 넣기는 불가능하지는 않지만주의해서 처리해야합니다. 코드의 환경, 라이브러리, 버전 등과 같은 종속성은 현재 프로젝트와 일치하지 않으므로 오류 또는 예측할 수없는 결과를 초래할 수 있습니다. 파일 경로, 종속 라이브러리 및 Python 버전을 포함하여 컨텍스트가 일관되게 유지하십시오. 또한 특정 라이브러리의 코드를 복사 및 붙여 넣을 때 라이브러리 및 해당 종속성을 설치해야 할 수도 있습니다. 일반적인 오류에는 경로 오류, 버전 충돌 및 일관되지 않은 코드 스타일이 포함됩니다. 성능 최적화는 코드의 원래 목적 및 제약에 따라 재 설계 또는 리팩토링되어야합니다. 복사 코드를 이해하고 디버그하고 맹목적으로 복사하여 붙여 넣지 않는 것이 중요합니다.
