手撕python之基本数据类型以及变量

news2025/1/12 1:02:46

​​​​​​1.基础概念

python就是将不同的数据划分成了不同的类型

就像我们生活中的数据有数字、字符等数据一样

小知识点:

注释:#

全体注释:Alt+F3

取消注释:Alt+F4

2.数值类型

数值类型概括

数值类型分为三种:整型int 浮点型 float 布尔型 bool

整型:1 2 3 4 5 6

浮点型: 1.1 3.1415926 5.20

布尔型:True False

我们在交互模式中输入type(数据)就能显示你所输入的数据的类型

type能够在交互模式查看数据类型

type在交互模式的用法:

123
type(123)     
<class 'int'>

type(1.5)     
<class 'float'>

type(True)     
<class 'bool'>

在括号内输入你想判断的数据,直接回车就能返回这个数据的类型

对于交互模式中bool值的判断:

123
2>1
True
1<0.5
False
1>2
False

输入我们要判断的表达式,然后系统会对这个表达式进行判断,返回对应的bool值

注意我们这个的bool类型的两个值True和False 开头的字母一定要是大写的,否则是会报错的

为什么这个布尔值是属于数值类型呢?

#为什么这个布尔值是属于数值类型呢?
#我们在交互模式使用True+1就输出了一个2
#使用False+1就是输出的是1
True+1
2
False+1
1

实际上False表示的是0

True表示的是1

我们在交互模式利用上述的加法就能判断出这个结果

所以我们的True除了表示真,还能表示1

False除了表示假,还能表示0

算术运算符

在我们的python中,True和False同时也代表着1和0,我们可以直接进行运算

True+False=1

对于表中的两个操作符:/和//

一个/的话就是编译器会进行小数的保留

两个//的话就是编译器会将小数部分删除,仅仅只保留住整数部分

对于%这个运算符的话,10/3=3….1

那么这个1就是10%3的结果,就是余数

运算符使用方法:

2*3
6

10**2
100

10/3
3.3333333333333335

10//3
3

10%3
1

我们的所有运算符符号一定要用英文符号

我们在进行算术运算中,只要我们的连个数据中一个数据是浮点数的话,那么结果一定会是浮点数的

一个数据是浮点数,结果一定是浮点数的:

10//3.0
3.0
10//2.0
5.0

只要有浮点数参与运算,那么结果一定是浮点数

对于负数进行呢取整以及其他的操作:

-10//5
-2
-10/3
-3.3333333333333335
-10//3
-4

如果我们是对负数进行取整的话,假如-10//3=-4

因为我们进行取整的话就是比原先不取整的值小一些

不管是整数还是负数都一样,取整就直接将小数部分剔除了

取余%--两数相处,商为余数,取余数部分

幂运算 *就是几次方 *102=100

-10%3
2
-10//4
-3

为什么-10%3得到的是2呢,因为%是进行求余数的操作的

我们的-10//4=-3 我们这里是直接取整的,后面剩下的我们没要直接舍去

但是-4*3=-12

就是说明我们的余数是2,被丢弃的那一部分是2

那么我们的-12+2=-10

那么-10%3=2

所以说负数取余数的话是有技巧的

就是-12< -10的相隔是2

3.字符串

概念:

字符串有三种定义方式:

1.单引号

2.双引号

3.三引号(三对单引号和三对双引号)

单引号和双引号使用时注意事项

python
Traceback (most recent call last):
  File "<pyshell#0>", line 1, in <module>
    python
NameError: name 'python' is not defined
#如果不加引号就是会报错的
'python'
'python'
"python "
'python '

如果我们在交互模式直接输入python这串字符的话,那么是肯定会报错的

我们需要将这串字符用引号包裹起来

如果我们不用引号括起来的,那么编译器就会以为这个是一个名称,就会检查我们这个名字有没有定义过,没有定义是一定会报错的

如果是文本数据的话,我们一定要用引号括起来的,不然是会报错的

英文和中文的引号是不一样的

我们需要的是英文版本的引号

我们利用type()来进行数据类型的判断,这里编译器输出的是str就是字符串

字符串类型的判断:

type('python')
<class 'str'>

type("python")
<class 'str'>

type('123')
<class 'str'>

单引号和双引号本质上是没有多大的区别的

我们在交互模式输入"python"和'python' 输出的结果都是'python'

引号是对应匹配的

单引号对单引号

双引号对双引号

单引号带来的错误:

'I'am fine
SyntaxError: invalid syntax
#我们如果是这么写的话那么就会报错的
#因为单引号和双引号是成双成对的进行配对的

对于这个单引号带来的错误

如果我们的句子里面已经有单引号的话,那么我们是需要用双引号进行括起来的

如果我们还是用单引号的话,那么因为匹配的问题我们后面的那个单引号就没有配对成功了,就会报错

所以我们是需要进行一个双引号的包裹的

"I'am fine"   #回车
"I'am fine"

双引号和双引号匹配成功,那么中间的内容就会被括起来的,那么我们编译器就将中间的内容进行输出

'this is "box"'
'this is "box"'

引号是成对出现的,就近匹配的

单包双,双包单

•单引号和双引号区分的原因:为了嵌套【引号里面还有引号】使用,如果有这种情况,需要使用两种不同的引号

三引号使用时注意事项

三引号 三对单引号 三对双引号

'''
dsad d
dfk
dsbfkj
dasdas 
'''
"""
dsad d
dfk
dsbfkj
dasdas 
"""

我们使用三对单引号的话我们是能够实现任意换行的

直接将大型的文本进行注释

包裹在三引号之内的我们能随意换行进行注释

只有三引号能实现换行的操作

单引号和双引号是不能实现这个操作的

字符串加号和星号

数字+数字---相加

字符串+字符串--拼接

字符串的+法使用:

#交互模式
'2'+'3'
'23'
2+3
5

字符1+字符1得到的就是11

就是相当于拼接

数字*数字---两个数字进行相乘

字符串*正整数---字符串重复多少次

字符串的*的使用:

'5201314'*6
'520131452013145201314520131452013145201314'

4.格式化

三种格式化

%格式化

语法:'格式化的字符串'%(填充的数据)

占位符:我们需要在字符串里面占一个位置,用于放后面填充的数据

三种占位符:%s字符串 %d整数 %f浮点数

print('你的成绩是%f'%(12.4))

通过字符串内的占位符,然后我们在字符串外面输入我们要填充的数字

对于%f的话我们这里默认是6位小数

如果我们是想进行小数位的控制的话,那么我们需要在%和f中间加上.n

保留几位小数,这个n就是几

设置小数位的方法:

#设置小数位
print('你的成绩是%f'%(12.4))#默认保留6位小数
print('你的成绩是%.2f'%(12.4))#我们将其设置为2位小数

设置长度,超过我们设置的长度我们就不进行处理

如果没有超过我们设置的长度的话,我们就进行填充处理

默认的话是填充空格的

我们可以使其填充的数字是0

一般是不填充符号类的

#编辑模式
print('%3d'%(1))
print('%d'%(1))
#交互模式
  1
1
#可见的区别
如何将不足长度的地方设置为0呢?
我们在%3d前面加上0
那么不满足长度的地方就会自动填充为0了

只有长度不够的时候才会进行填充的

我们在表达num1+num2的结果的时候我们也是能用占位符的

输出 数字+数字=和 的格式:

#编辑模式
num1=eval(input("请输入数据1:"))
num2=eval(input("请输入数据2:"))
##print(num1+num2)
#我们使用格式化进行表示最终的结果
print('%d'%(num1+num2))
print('%f+%f=%f'%(num1,num2,num1+num2))
#每个占位符和数据进行对应的


#交互模式
请输入数据1:5
请输入数据2:6
11
5.000000+6.000000=11.000000

在这个表达式中对于%f那行代码的另一种写法

print('%s+%s=%s'%(num1,num2,num1+num2))
#我们直接将这个%f替换成%s就行了

#交互模式
5+6=11

为什么我们能进行代码中这么交换呢?

就是我们将这个代码中三个占位符对应的数据先转换为字符串

然后在打印的时候我们就能通过print将引号去掉了

但是还是不建议这种写法

如果是写%f的话,我们在前面加上.n进行小数位的控制

'%d'%(数据)

foramt占位符

语法:'格式化的字符串'.format(填充数据)

一定要看清楚

format前面有个小数点,别忘了加

占位符:{}

设置小数位数::.nf---保留n位小数 这里是冒号+点+nf 冒号的作用就是区分数据和格式的

format使用方法:

#编辑模式
print('你的大小是{:.2f}'.format(12.4))
print('你的大小是{:03d}'.format(1))
#交互模式
你的大小是12.40
你的大小是001

一定要在花括号里面写冒号

输出 数字+数字=和 的格式

#编辑模式
num1=eval(input("请输入数据1:"))
num2=eval(input("请输入数据2:"))
print('{}+{}={}'.format(num1,num2,num1+num2))
#交互模式
请输入数据1:5
请输入数据2:5
5+5=10

'{:,nf}.format()'

f表达式

这里的f是format的缩写

占位符:{}

语法格式:f'{格式化的数据}'

保留n个小数:

#编辑模式
print(f'{1:.2f}')#打印1保留两位小数
#冒号的作用是分割数据和格式
#交互模式
1.00

'f{格式化的数据:,nf}'

设置数据长度,不足填充数据,超过不做处理

#编辑模式
print(f'{1:05d}')
#交互模式
00001

输出 数字+数字=和 的格式

#编辑模式
num1=eval(input("请输入数据1:"))
num2=eval(input("请输入数据2:"))
print(f'{num1}+{num2}={num1+num2}')

print(f'{num1:03}+{num2:03}={num1+num2:03}')
#交互模式
请输入数据1:5
请输入数据2:6
5+6=11
005+006=011

对于花括号中的冒号的话,我们如果对数据有要求的话我们是能对其在冒号后面进行要求的

比如说在冒号后面加03d

如果没有要求的话我们是可以直接在花括号里面写个数据就行了

这三种方法中我感觉f表达式是最简单的格式化

小题目

1.键盘输入用户名,键盘输入密码,将用户名和密码信息进行格式化输出

格式为:'用户xxx你好,你的密码为xxx'

#编辑模式
name=input("请输入你的姓名")
code=input("请输入你的密码")
print('%s你好,你的密码是%s'%(name,code))
print('{}你好,你的密码是{}'.format(name ,code))
print(f'{name}你好,你的密码是{code}')
#交互模式
请输入你的姓名kyk
请输入你的密码666
kyk你好,你的密码是666
kyk你好,你的密码是666
kyk你好,你的密码是666

2.键盘输入用户电话,以及话费,用格式化进行输出了

tel=eval(input("请输入你的电话"))
money=eval(input("请输入话费"))
#因为我们这里输入的money是一个字符串,我们是不能对其小数位作调整的,不然是会报错的
#如果想要调整话费的小数点位的话,我们需要将我们输入的数据转换为浮点型
print(f'用户:{tel:013d},你这个月的话费为{money:.2f}')
#经过打印我们知道如果我们是字符串的话,长度不够的情况下,是在右边进行补空格的操作的
#那么我们将这个字符串类型进行改变,改成整形的话,那么填充的数字就是左边
#我们指定长度为13位,不满的话就填充0

关于不同类型对齐的知识

字符串在打印的时候长度不够的时候是在左边进行空格填充的操作的

整型就是在右边进行填充

那么我们如果进行数据在打印的时候的对齐方式呢?

我们可以在打印的时候使用对齐符

左对齐,右边填充<

右对齐,左边填充>

居中,两边填充^

那么是如何使用这三个符号呢?

字符串对齐符号的使用方式:

#字符串类型在右边填充,整形类型在左边填充
#设置填充数据的对齐方式----填充符   对齐方式   长度   ->      0<5    (长度为5,不足填充0,左对齐)
num=123
#左对齐<
print(f'{num:<5}')  #长度为5不足填充空格
print(f'{num:0<5}')#长度为5不足填充0
#右对齐>
print(f'{num:>5}')
#居中^
print(f'{num:0^5}')

#左对齐就在右边填充0,右对齐就在左边填充0,数据居中对齐就是在两边填充0

填充符 对齐方式 长度 -> 0<5 (长度为5,不足填充0,左对齐)

这里是以f表达式为例子

5.变量

变量的命名以及赋值

变量是什么呢?

变量:可变的量,值是可以进行改变的

我们通过赋值符号“=”进行赋值

我们可以保存任意类型的数据

这个变量就相当于一个容器,这个容器是可以进行数据的存放的

我们能通过这个这个容易的名字进行数据的调用

定义格式:变量名=值

变量名:自己定义,我们需要遵循命名规则

值:数据

命名规则

1.只能有数字、字符、下划线_

2.不能以数字开头

3.不能有特殊的字符,如标点符号等

定义一个变量来存放名字

这个名字是一个文本,算是字符串,我们用双引号或者单引号包裹

使用变量格式:变量名

#编辑模式
name='小明'
#交互模式
name   回车
'小明'

我们在编辑模式对这个name进行定义,然后运行进入到交互模式里面,然后直接输入name 回车,编译器输出的就是我们之前对name的定义的数据

通过变量名我们是可以获取对应的数据的

#编辑模式
print(name)
#交互模式
小明

变量名我们是需要先进行定义我们才能进行使用的

文本数据被定义的话我们一定要用引号进行括起来的

如果我们用print进行打印的话,编译器会直接过滤掉引号

但是我们直接将变量拿出来到交互模式的话那么就不会去引号的

变量的多重定义,那么最后一次定义的就是我们最终变量里面存储的

#编辑模式
name='小明'
print(name)

name =1
print(name)

name ='小妹'
print(name)
#交互模式
小明
1
小妹

每次定义都是重新定义的,不管之前这个变量名有没有被定义,都以最后一次为基准

最后一次被定义的是啥,这个变量里面存的就是啥

就是新的值会将旧的值进行替换

这个就是重新赋的概念

同时定义多个变量:左边变量名数量和右边的值数量一定要一致

#编辑模式
a,b,c=1,2,3
print(a)
print(b)
print(c)
#交互模式
1
2
3

多个变量进行命名,我们一定要数量对应好

姓名和数据要对应好

官方式命名法:用下划线连接两个英文组成的名称

'''
假设现在猪肉 15块钱一斤,西兰花 6块一斤,辣椒 12块钱一斤
现在买2斤猪肉,1斤西兰花,2斤辣椒需要多少钱?
'''
zhurou=15
xilanhua=6
lajiao=12
print(zhurou*2+xilanhua*1+lajiao*2)
然后编译器输出的就是60

'''
第二天猪肉涨价为18块钱一斤
买同样的材料需要多少钱?

那么我们现在只需要将这个猪肉的价格进行修改就行了
'''
zhurou=18
print(zhurou*2+xilanhua*1+lajiao*2)
编译出来的就是66

关键字和内置函数

我们在对变量进行命名的时候我们是不能用关键字进行命名的

那么我们是怎么进行关键字的查看呢?

查看关键字的方式:

#查看关键字
import keyword
print(keyword.kwlist)

'''
['False', 'None', 'True', 'and', 'as', 'assert', 'async', 'await',
'break', 'class', 'continue', 'def', 'del', 'elif', 'else',
'except', 'finally', 'for', 'from', 'global', 'if', 'import',
'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise',
'return', 'try', 'while', 'with', 'yield']

关键字:保留字,回赋予一些特殊的含义

我们是不能用这些关键字进行变量名字的定义的

举例:我们之前学到的True就是真,表示的是1

但是现在我们将这个进行重新赋值,那么这个表示的大小就被重新替换掉了

那么这个就对代码产生了极大的危害

我们是没有这个权限对关键字进行重新赋值的

但是true和false是可以进行变量的命名的

因为开头字母是小写的,不是关键字

关键字的颜色一般是橙色的

我们的变量名一般就是黑色的

紫色的就是python里面的内置函数,也是不能用来对变量进行命名

查看内置函数的方式:

#编辑模式
print(dir(__builtins__))

#交互模式
'''
['False', 'None', 'True', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
['ArithmeticError', 'AssertionError', 'AttributeError', 'BaseException', 'BaseExceptionGroup', 'BlockingIOError', 'BrokenPipeError', 'BufferError', 'BytesWarning', 'ChildProcessError', 'ConnectionAbortedError', 'ConnectionError', 'ConnectionRefusedError', 'ConnectionResetError', 'DeprecationWarning', 'EOFError', 'Ellipsis', 'EncodingWarning', 'EnvironmentError', 'Exception', 'ExceptionGroup', 'False', 'FileExistsError', 'FileNotFoundError', 'FloatingPointError', 'FutureWarning', 'GeneratorExit', 'IOError', 'ImportError', 'ImportWarning', 'IndentationError', 'IndexError', 'InterruptedError', 'IsADirectoryError', 'KeyError', 'KeyboardInterrupt', 'LookupError', 'MemoryError', 'ModuleNotFoundError', 'NameError', 'None', 'NotADirectoryError', 'NotImplemented', 'NotImplementedError', 'OSError', 'OverflowError', 'PendingDeprecationWarning', 'PermissionError', 'ProcessLookupError', 'RecursionError', 'ReferenceError', 'ResourceWarning', 'RuntimeError', 'RuntimeWarning', 'StopAsyncIteration', 'StopIteration', 'SyntaxError', 'SyntaxWarning', 'SystemError', 'SystemExit', 'TabError', 'TimeoutError', 'True', 'TypeError', 'UnboundLocalError', 'UnicodeDecodeError', 'UnicodeEncodeError', 'UnicodeError', 'UnicodeTranslateError', 'UnicodeWarning', 'UserWarning', 'ValueError', 'Warning', 'WindowsError', 'ZeroDivisionError', '__build_class__', '__debug__', '__doc__', '__import__', '__loader__', '__name__', '__package__', '__spec__', 'abs', 'aiter', 'all', 'anext', 'any', 'ascii', 'bin', 'bool', 'breakpoint', 'bytearray', 'bytes', 'callable', 'chr', 'classmethod', 'compile', 'complex', 'copyright', 'credits', 'delattr', 'dict', 'dir', 'divmod', 'enumerate', 'eval', 'exec', 'exit', 'filter', 'float', 'format', 'frozenset', 'getattr', 'globals', 'hasattr', 'hash', 'help', 'hex', 'id', 'input', 'int', 'isinstance', 'issubclass', 'iter', 'len', 'license', 'list', 'locals', 'map', 'max', 'memoryview', 'min', 'next', 'object', 'oct', 'open', 'ord', 'pow', 'print', 'property', 'quit', 'range', 'repr', 'reversed', 'round', 'set', 'setattr', 'slice', 'sorted', 'staticmethod', 'str', 'sum', 'super', 'tuple', 'type', 'vars', 'zip']
'''

6.变量的输出与输入

输出print

输出我们用的是print函数

print(要输出的内容)

将括号内的内容进行一个打印,打印到交互面板

如果我们通过print函数来输出字符串的话那么编译器就是自动将引号省略

输出引号内的内容

我们的括号里面还能放表达式,编译器会在计算之后将其进行输出的

但是我们如果要输出多个数据应该怎么做呢?

多内容的打印方式:

#编辑模式
print('abcd',1+1,4**2)
#交互模式
abcd 2 16

我们在print的括号内用逗号将多个内容进行隔离

print(内容一,内容二,内容三)

打印出来的数据就是:内容一 内容二 内容三

分隔符---sep

换行是怎么操作的呢?我想要多个数据各为一行

设置多个数据时,数据之间的分隔符

sep是可以设置分隔符的,就是数据与数据之间用什么进行分开,我们是可以控制的

sep的位置通常在打印括号内的最后一个位置

sep来控制分隔符号:

#编辑模式
print('abcd',1+1,4**2,sep=";")#设置以分号进行分割
print('abcd',1+1,4**2,sep=":")#设置一冒号进行分割
print('abcd',1+1,4**2,sep="6")#设置一6进行分割
#交互模式
abcd;2;16
abcd:2:16
abcd62616

如果我们是不设置分隔符的话那么默认的分隔符就是一个空格

如果我们想换行,怎么用sep实现呢?

#编辑模式
print('abcd',1+1,4**2,sep="\n")
#交互模式
abcd
2
16

我们将分隔符设置为'\n'就行了

\n就是换行的操作,就是编译器帮我们进行回车的操作

想要被打印的数据之间用什么符号进行间隔,我们通过sep='分隔符'这个操作就能进行实现了

end的使用

为什么我们的每个单独的print函数的后面好像是有个换行符一样,我们不需要进行写sep就能换行

#编辑模式
print(1)
print(2)
print(3)
#交互模式
1
2
3

设置内容回输出完毕之后以什么内容结尾

end='结尾符',结尾默认是换行

我们这里的print的结尾符默认是换行\n

我们没有在括号内设置的,系统堆print是默认是换行的

一句print就是一行的

但是我们现在不想默认换行了怎么办,我么想用其他的符号进行运用

#编辑模式
print(1,end="+")
print(2)
print(3)

print(3,end="*")
print(4)
#交互模式
1+2
3
3*4

我们在这里没有以换行符进行结尾

我们以+和*进行结尾

那么我们输出的就是

1+2

3

3*4

我们将默认的换行符变为其他的符号进行结尾

end和sep的区别

区别:

#编辑模式
print(1,sep="!")

print(1,end="+")
#交互模式
1
1+

我们的sep只有在多个数据存在的时候才能发挥作用

只有一个数据的话是不会生效的,两个及以上的数据才会生效

但是我们的end就不一样,end是直接在结尾设置我们想要的符号,不管是几个数据

不管是end还是sep,前面的逗号一定要是英文逗号,不能是中文逗号

输入input

格式:input("提示内容")

我们能在交互模式通过键盘输入数据

作用:你想给计算机什么信息,则使用输入函数录用,通过排变量进行保存

注意:input接收到的所有数据都是字符串类型,可以通过类型转换为对应的数据类型

input返回的是字符串类型,所以我们需要进行类型转换,转换为对应的类型进行正确的操作

name=input("请输入你的名字:")#定义变量,存放输入的数据
print(name)

input括号内的是输入我们的提示信息,提醒用户输入

在输入数据之后,这个数据就被存放到了name里面了

然后我们将其进行打印,然后就得到了我们输入的东西了

我们需要按下回车键告诉编译器我们已经输入完了,然后由编译器进行后面的其他操作

我们一定是要在input后面的括号内输入提示信息,不然后面代码量提高了就很不方便的

一定要在交互模式进行键盘的输入数据,输入完数据需要回车才能结束等待输入的状态

#键盘输入两个数字,进行加法操作,并将值给他进行输出
#编辑模式
num1=input("请输入第一个数字")
num2=input("请输入第二个数字")
print(num1+num2)
#交互模式
请输入第一个数字12
请输入第二个数字12
1212

为什么我们最后的的结果是1212呢?

好像就是将我们输入的两个值进行了拼接一样

怎么和字符串的加法一样呢?

对于input来说,我们不管输入什么,系统都会将我们输入的看作是一个字符串

所以我们这里的结果就是和字符串拼接效果是一样的

为了能使用我们输入的数字进行加法操作,我们需要将我们输入的数据转换为整型类型的数据

然后就能进行整型的相加了

下面我们就介绍转换数据类型

转换数据类型

数据类型:整型(Int)浮点型(float)字符串(str)

如果我们需要将浮点型转换为整型该怎么操作呢?

int(我们写的浮点型)

int(12.4)

那么转换出来的就是12

只保留整数部分,舍去小数部分

将字符串转换为整型进行输出

print(int('123'))

输出123

str()将输入的数据转换为字符串

整形转换为为浮点型就是在后面添加小数部分

字符串转换为浮点型其实都差不多

对于字符串转换为整型的时候,我们字符串引号里面的字符只能够是数字

不能够是字母,因为我们字母是不能变成数字的

那么回到上面的题目我们就能将我们输入的进行相加

##键盘输入两个数字,进行加法操作,并将值给他进行输出
num1=input("请输入第一个数字")
num2=input("请输入第二个数字")
print(int(num1)+int(num2))

我们直接在打印的括号里面将我们输入的数字进行转换为整型

任何数据转换为字符串直接将数据用引号括起来

我们不仅可以在输入的时候进行转换,我们也可以在使用的时候进行打印的时候转换

##键盘输入两个数字,进行加法操作,并将值给他进行输出
num1=int(input("请输入第一个数字"))
num2=int(input("请输入第二个数字"))
print(num1+intnum2)

直接在我们输入完就进行转换为整型

然后两个整型的相加

eval--将字符串的引号去除

eval(字符串):将字符串的引号去除,只显示引号里面的数据

我们现在想实现输入的是什么数据就准确转换什么数据

eval的使用:

num=eval(input("请输入数据"))
print(type(num))
print(num)

我们直接利用eval在输入的时候将字符串的引号进行去除

我们输入的数据为字符串类型的话,那么我们就不能使用eval了

就会报错了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2077860.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Cesium 展示——动态洪水淹没效果

文章目录 需求分析1. 引入插件2. 定义变量3. 开始绘制3.1 绘制点3.2 绘制线3.3 绘制面3.4 开始分析(第一种)3.5 开始分析(第二种)3.6 方法调用4. 整体代码其他需求 从低处到高处实现洪水淹没效果 分析 本篇文章对方法进行单独抽离,因此支持拿来即用,注意传参就可 1. …

宠物系统小程序的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;用户管理&#xff0c;商品信息管理&#xff0c;店主管理&#xff0c;猫狗查询管理&#xff0c;猫狗宠物社区&#xff0c;管理员管理&#xff0c;系统管理 微信端账号功能包括&#xff1a;系统首页&…

宝塔 出现 请使用正确的入口登录面板

目录 前言1. 问题所示2. 原理分析3. 解决方法 前言 记录实战中所有的问题导向、原理分析以及解决方法 1. 问题所示 在登录宝塔的时候&#xff0c;出现如下问题 请使用正确的入口登录面板 错误原因&#xff1a;当前新安装的已经开启了安全入口登录&#xff0c;新装机器都会随…

使用redis模拟cookie-session,例子:实现验证码功能

目录 在前后端分离架构中不建议使用cookie-session机制实现端状态识别 所以我们可以使用redis来模拟session-cookie机制 下面我们通过实现验证码的功能来举例 第一步&#xff1a;了解前端要我们返回的数据变量名字&#xff0c;变量类型 1.封装code,data成一个result类&…

多模态技术应用场景探析,景联文科技多模态数据测试平台推动多模态大模型技术突破

多模态技术应用场景探析&#xff0c;景联文科技多模态数据测试平台推动多模态大模型技术突破 在大语言模型背景下&#xff0c;多模态技术的发展已成为一个重要趋势。 Sora是OpenAI推出的多模态大模型&#xff0c;具备高级视频生成与编辑功能&#xff0c;支持长视频、多视角、多…

使用OpenCV库来捕获摄像头视频流,并按指定格式保存

今天我们来使用OpenCV库来捕获摄像头视频流&#xff0c;并将其保存为AVI格式的视频文件&#xff0c; 代码的主要功能包括&#xff1a; 初始化摄像头捕获对象。设置视频编解码器和输出文件路径。循环读取视频帧&#xff0c;处理并保存到文件中。显示处理后的视频帧。按下q键退…

Python | 处理海洋2C 数据 | 非标准时间格式

写在前面 最近&#xff0c;师弟在用Python读取某海洋2C数据时&#xff0c;突然冒出一个报错&#xff1a;“时间单位的参考日期无效&#xff0c;当前日期 00:00:00.0”。这让我回想起&#xff0c;似乎在很久很久以前&#xff0c;我处理SMAP和Argo数据时也遇到过类似的问题。为了…

JavaScript 模块化开发:ES6 模块与 CommonJS 的对比与应用

​ ​ 您好&#xff0c;我是程序员小羊&#xff01; 前言 随着前端项目规模的增长&#xff0c;代码组织和管理变得越来越复杂。模块化开发成为解决这一问题的有效手段&#xff0c;能够帮助开发者将代码进行分割、复用和维护。JavaScript 在发展过程中出现了多种模块化规范&…

【精通SDL之----使用PBO异步传输像素数据】

使用PBO异步传输像素数据 前言一、 一些GPU 分配的常用内存对象介绍二、 PBO 传输原理三、 PBO 使用方法 前言 书接上文【精通SDL之----SDL_RenderReadPixels截屏】&#xff0c;SDL_RenderReadPixels在GLES2上是一个非常耗时的操作&#xff0c;因为   1. OpenGL ES 是一个异步…

.NET Razor类库 - 静态资源组件化

1. 找到Razor类库 打开VS2022 文件 - 新建 - 项目 或者 使用 CtrlShiftN 快捷键 输入Razor 搜索 &#xff0c; 选中Razor类库&#xff0c; 点击 下一步2.创建Razor类库项目 输入项目名称 IX.RCL.Front RCL 是 RazorClassLibrary的简称意思 Front 代表前端静态资源的意思 位…

KEIL Stm32 bin文件生成的两种方法以及报错的处理

Keil里生成bin文件的方法有两种&#xff0c;记录如下&#xff0c;以免忘记~ 首先&#xff0c;在Keil主页面&#xff0c;点击如下按钮&#xff0c;打开Options for Target ‘target 1’对话框&#xff0c;并选择User标签页。 其次&#xff0c;通过在 User标签页 设置 “After B…

一种基于 JavaEE 的合同管理系统,用于存储、管理和跟踪合同的软件工具,功能很完善(附源码)

前言 在现代企业管理中&#xff0c;合同管理是一项至关重要的任务。传统的手动管理合同不仅耗时耗力&#xff0c;而且容易出现错误和遗漏&#xff0c;导致合同执行效率低下&#xff0c;甚至面临法律风险。随着业务的不断扩展&#xff0c;越来越多的企业开始寻求一种更为高效、…

作为HR,如何解决简历筛选难度大的问题

简历筛选需要耗费大量的时间和精力&#xff0c;尤其是当应聘者过多的情况下&#xff0c;往往让HR精疲力竭&#xff0c;而且效率低下。当下也有很多这方面的工具可以辅助的&#xff0c;如&#xff1a;招聘管理&#xff0c;简历解析类等。 借助软件&#xff0c;可以更好的获取简…

GLM-4-Flash 大模型API免费了,手把手构建“儿童绘本”应用实战(附源码)

老牛同学刚刷到了一条劲爆的消息&#xff0c;GLM-4-Flash大模型推理 API 免费了&#xff1a;https://bigmodel.cn/pricing 老牛同学一直觉得上次阿里云百炼平台为期 1 个月免费额度的“羊毛”已经够大了&#xff08;太卷了&#xff0c;阿里云免费 1 个月大模型算力额度&#xf…

什么是BI?BI系统的功能有哪些?哪些人需要BI工具支持?

什么是BI&#xff1f; BI是商业智能&#xff08;Business Intelligence&#xff09;的缩写。它是指通过收集、整理、分析和可视化企业内部和外部数据&#xff0c;从中获得洞察信息和决策支持的技术和流程。BI利用数据分析工具和技术&#xff0c;帮助企业管理者和决策者更好地理…

Cesium 展示——获取指定区域地形的最大最小高程

文章目录 需求分析方法一:方法二:需求 在地图上勾选某一处的区域,分析获取区域内最大最小高程 分析 方法一: function getAreaHeight(viewer, positions) {const startP = positions[0

备考AMC10美国数学竞赛2024:吃透1250道真题和知识点(持续)

有什么含金量比较高的初中生数学竞赛吗&#xff1f;美国数学竞赛AMC10是个不错的选择。那么&#xff0c;如何备考AMC10美国数学竞赛呢&#xff1f;做真题&#xff0c;吃透真题和背后的知识点是备考AMC8、AMC10有效的方法之一。 通过做真题&#xff0c;可以帮助孩子找到真实竞赛…

解决tensorflow模型加载时把GPU显存占满的问题(亲测效果显著)

第一次用tensorflow模型进行推理。 初始状态下&#xff0c;显存的占用情况 模型加载后&#xff0c;电脑显存直接快拉满了&#xff0c;但是模型参数量并不大&#xff0c;这就很奇怪,究竟这是一股什么神秘的力量&#xff0c;竟要试图侵占我可怜的显卡宝贝 原因分析:安装了tensor…

fastadmin表单中二维数组组件+图片上传

记录&#xff1a;fastadmin表单中二维数组组件图片上传 add.html代码 <div class"form-group"><label class"control-label col-xs-12 col-sm-2">{:__(Quanyi)}:</label><div class"col-xs-12 col-sm-10"><style>…

多个FeignClient使用相同服务名报错问题:使用contextId区分不同FeignClient

一、概述 在项目开发中&#xff0c;由于多个 FeignClient 使用了相同的 name &#xff0c;导致SpringBoot启动时出现 BeanDefinitionOverrideException 异常。 解决方案是在每个 FeignClient 上添加唯一的 contextId&#xff0c;如 userFeignClient 和 helloWorldFeignClient…