当前位置:   article > 正文

【Python】Python基本概念、print()输出函数、标准数据类型、type()函数与isinstance()函数、数据类型转换、变量与变量名的命名规则、注释_python print输出字符串和变量

python print输出字符串和变量

1、Python基本概念

1、编译器&解释器 :

将代码编译成计算机能够识别的命令 计算机可以识别的机器码 0 1

区别:

编译器:全文翻译,编译型语言

解释器:实时翻译,解释型语言

2、python语言介绍

  • 翻译的角度 :

  • 解释型语言,编译型语言

  • 高低语言维度 :

  • 低级编程语言:代码可以直接被计算机识别:汇编语言

  • 高级编程语言:代码无法直接被计算机识别,需要通过转换:c java python

3、Python 的优点

语法简洁&适合入门

非常强大的类库

开发效率高

4、python解释器

Cpython:python官方解释器

JPython

IronPython

pypy

Ipython

5、Python默认编码格式

默认的编码格式UTF-8

如果要修改默认的编码格式则需要在文件头添加新的编码格式,然后运行;

  1. # -*- coding:GBK -*-
  2. print("你是我的眼")


2、Python编译之简单输出

print("Hello Python")

想要让原本在一行的内容进行换行,可以这样做:

  1. print("你好""中国")
  2. print("你好\n""中国")

如果直接输出语句,那么输出一句后则默认会换行;

  1. print("春眠不觉晓")
  2. print("处处闻啼鸟")

如果不想让它换行,则可以在所输出内容的末尾加上end=""

  1. print("夜来风雨声",end=",")
  2. print("花落知多少",end="。")

3、print()输出函数

print在python2中是一个关键字,使用时不必加括号;但在python3中是一个函数,使用时需要加括号。python3.3版本增加了flush参数。

print(self, *args, sep=' ', end='\n', file=None) # known special case of print

参数的具体含义如下:

  • sep -- 用来间隔多个对象。

  • end -- 用来设定以什么结尾。默认值是换行符 \n,我们可以换成其他字符。

  • file -- 要写入的文件对象。

  1. print("www", "baidu", "com", sep="@") # 设置间隔符为@
  2. print("www", "baidu", "com", sep=".") # 设置间隔符为.
  3. print()
  4. a = 1
  5. b = "Hello World"
  6. print(a, b) # 一次可以输出多个变量,变量之间必须用逗号分隔
  7. print()
  8. # 如果直接输出字符串,可以不使用逗号,使用逗号则表示空格
  9. print("李白""李白")
  10. print("李白", "李白")
  11. print("Hai""Hai", sep='$', end='@', file=None ,flush=False)
  12. #这里设置$为间隔符,@为结尾符
  13. #如果多个字符串之间没有用逗号隔开,那么用sep设置了间隔符也没有效果
  14. print()
  15. print("Hai","Hai", sep='#', end='@', file=None ,flush=False)
  16. #必须用逗号隔开,sep设置了间隔符才有效果

运行结果:


4、标准数据类型

文本类型:

str

数值类型:

int, float, complex

序列类型:

list, tuple, range

映射类型:

dict

集合类型:

set, frozenset

布尔类型:

bool

二进制类型:

bytes, bytearray, memoryview

整数型int

整数类型是python中常用的数据类型,简称int,全程integ,可以用来运算

  1. print(3+2) #加法运算
  2. print(3-2)   #减法运算
  3. print(3/2)   #除法运算(如果除不尽会有小数)
  4. print(3//2) #求商的除法运算:只取商,不要小数
  5. print(3*2) #乘法运算
  6. print(3**2) #次幂运算:32次幂

布尔类型bool

  1. print(1>2)
  2. print(1 == 1)

浮点型float

  1. print(0.1*0.1)
  2. print(0.1+0.1)
  3. print(4.4%2)
  4. print(4.4/2)
  5. print(0.1**2)

为什么会出现上面的结果呢?

其原因在于十进制和二进制的转换上,计算机先要把十进制的数转化为二进制,然后再计算。

但是,在转化中,浮点数转化为二进制,就出问题了,例如:

十进制的 0.1,转化为二进制是:0.0001100110011001100110011001100110011001100110011…

也就是说,转化为二进制后,不会精确等于十进制的 0.1。

同时,计算机存储的位数是有限制的,所以,就出现上述现象了。

复数类型complex

复数由实部(real)和虚部(imag)构成,在 Python 中,复数的虚部以j或者J作为后缀,具体格式为:

a + bj #a 表示实部,b 表示虚部
  1. a=complex(1, 2)
  2. b=complex(3)
  3. print(a,b)
  4. c1 = 12 + 0.2j
  5. print("c1值: ", c1)
  6. print("c1数据类型:", type(c1))
  7. c2 = 6 - 1.2j
  8. print("c2值: ", c2)
  9. #对复数进行简单计算
  10. print("c1+c2: ", c1+c2)
  11. print("c1*c2: ", c1*c2)
  12. print("c1*c2数据类型:", type(c1+c2))
  13. print("c1*c2数据类型:", type(c1*c2))

运行结果:

字符串String

  1. 单引号 ' '

  1. 双引号 " "

  1. 多引号 """ """ ''' '''

  1. +的作用:表示字符串拼接

  1. *的作用:表示字符串出现了几次

单引号、双引号与多引号

  1. print("hello world")
  2. print('hello world')
  3. print("""hello world""")

运行结果:

可以在单引号中包含双引号,或者在双引号中包含单引号;

  1. print("Hello 'Python'")
  2. print('Hello "Python"')

正常情况下,单引号和双引号的字符串是不支持直接在符号间换行输入的,以下两种方式可以实现;

方法一:

\n转义换行,是使用在引号里才能有效果

  1. print("Hello 'Python'")
  2. print("Hello\n'Python'") #转义换行
  3. print(r"Hello\n'Python'") #加上r,显示原始字符串

方法二:

多引号

  1. print("""
  2. hello
  3. python
  4. """)
  5. print('''
  6. hello
  7. world
  8. ''')

+的作用

  • String + String 字符串的拼接

  1. print("崔倍"+"王七")
  2. print(3*"我爱猫爷\n")

*的作用

  • N * String 字符串String出现N次拼接起来


5、type()函数与isinstance() 函数

type() 可以用来查询变量所只带的对象类型

  1. a=1
  2. b=0.1
  3. c="Hi!"
  4. print(type(a))
  5. print(type(b))
  6. print(type(c))

isinstance() 函数来判断一个对象是否是一个已知的类型,类似 type()。

isinstance(object, classinfo) #isinstance的语法
  • object -- 实例对象。

  • classinfo -- 可以是直接或间接类名、基本类型或者由它们组成的元组。

  1. a = 2
  2. isinstance (a,int)
  3. isinstance (a,str)
  4. isinstance (a,(str,int,list)) # 是元组(str,int,list)中的一个,所以返回 True
  5. isinstance (a,(str,bool,complex)) # 不是元组(str,bool,complex)中的一个,所以返回 False
  6. print(isinstance (a,int))
  7. print(isinstance (a,str))
  8. print(isinstance (a,(str,int,list)) )
  9. print(isinstance (a,(str,bool,complex)))

type()函数与isinstance()函数的区别

isinstance() 与 type() 区别:

  • type() 不会认为子类是一种父类类型,不考虑继承关系。

  • isinstance() 会认为子类是一种父类类型,考虑继承关系。

如果要判断两个类型是否相同推荐使用 isinstance()。


6、数据类型转换

Python 数据类型转换可以分为两种:

  • 隐式类型转换 - 自动完成

  • 显式类型转换 - 需要使用类型函数来转换

隐式类型转换

在隐式类型转换中,Python 会自动将一种数据类型转换为另一种数据类型,不需要我们去干预。

在下面的实例中,我们对两种不同类型的数据进行运算,较低数据类型(整数)就会转换为较高数据类型(浮点数)以避免数据丢失。

  1. num_int = 123
  2. num_flo = 1.23
  3. num_new = num_int + num_flo
  4. print("num_int的类型:",type(num_int))
  5. print("num_flo的类型:",type(num_flo))
  6. print("num_new的值:",num_new)
  7. print("num_new的类型:",type(num_new))
代码解析:
1、实例中我们对两个不同数据类型的变量 num_int 和 num_flo 进行相加运算,并存储在变量 num_new 中。
2、然后查看三个变量的数据类型。
3、在输出结果中,我们看到 num_int 是 整型(integer) , num_flo 是 浮点型(float)。
4、同样,新的变量 num_new 是 浮点型(float),这是因为 Python 会将较小的数据类型转换为较大的数据类型,以避免数据丢失。

我们再看一个实例,整型数据与字符串类型的数据进行相加

  1. num_int = 123
  2. num_str = "456"
  3. print("num_int的类型:",type(num_int))
  4. print("num_str的类型:",type(num_str))
  5. print(num_int+num_str)
从输出中可以看出,整型和字符串类型运算结果会报错,输出 TypeError。 Python 在这种情况下无法使用隐式转换。
但是,Python 为这些类型的情况提供了一种解决方案,称为显式转换。

显式类型转换

在显式类型转换中,用户将对象的数据类型转换为所需的数据类型。 我们使用 int()、float()、str() 等预定义函数来执行显式类型转换。

int() 强制转换为整型:

  1. x = int(1) # x 输出结果为 1
  2. y = int(2.8) # y 输出结果为 2
  3. z = int("3") # z 输出结果为 3
  4. print(x,y,z)

float() 强制转换为浮点型:

  1. x = float(1) # x 输出结果为 1.0
  2. y = float(2.8) # y 输出结果为 2.8
  3. z = float("3") # z 输出结果为 3.0
  4. w = float("4.2") # w 输出结果为 4.2

str() 强制转换为字符串类型:

  1. x = str("s1") # x 输出结果为 's1'
  2. y = str(2) # y 输出结果为 '2'
  3. z = str(3.0) # z 输出结果为 '3.0'

整型和字符串类型进行运算,就可以用强制类型转换来完成:

  1. num_int = 123
  2. num_str = "456"
  3. print("num_int 数据类型为:",type(num_int))
  4. print("类型转换前,num_str 数据类型为:",type(num_str))
  5. num_str = int(num_str) # 强制转换为整型
  6. print("类型转换后,num_str 数据类型为:",type(num_str))
  7. num_sum = num_int + num_str
  8. print("num_int 与 num_str 相加结果为:",num_sum)
  9. print("sum 数据类型为:",type(num_sum))

常用数据类型转换函数

函 数

作 用

int(x)

将 x 转换成整数类型

float(x)

将 x 转换成浮点数类型

complex(real,[imag])

创建一个复数

str(x)

将 x 转换为字符串

repr(x)

将 x 转换为表达式字符串

eval(str)

计算在字符串中的有效 Python 表达式,并返回一个对象

chr(x)

将整数 x 转换为一个字符

ord(x)

将一个字符 x 转换为它对应的整数值

hex(x)

将一个整数 x 转换为一个十六进制字符串

oct(x)

将一个整数 x 转换为一个八进制的字符串

  • 转换int整型,必须是数字,可以有引号也可以没有;

  • 转换str字符串,必须用引号括起来;

  • 转换bool,结果只有True/False;

  • 转换float,必须是数字

  1. print(int("123"))
  2. print(int('123'))
  3. print(int(1234))
  4. print()
  5. print(float(1))
  6. print(float(1.0))
  7. print()
  8. print(bool(1))
  9. print(bool(True))
  10. print(bool(False))
  11. print(bool(""))
  12. print(bool(0)) #当bool函数里的对象为空字符串,空元组,空列表,空字典和 0 时结果为False,其他时候均为True
  13. print()
  14. print(str("你好"))
  15. print(str('你好'))
  16. print()
  17. print(float(1))
  18. print(float("123"))


7、变量

  1. country = "中国"
  2. address = "我爱"+ country
  3. print(address)
  4. age = 18
  5. print(age)
  6. flag = 1 < 18
  7. print(flag)
  8. a = b = c = 1
  9. print(a,b,c)
  10. a,b,c = "A",2,3
  11. print(a,b,c)

变量名的命名规则

1、变量名只能有字母,数字,下划线组成

2、数字不能开头

3、不能使用python关键字

最好见名知意,写成驼峰体(例如 MyPython)

(下图是常见的关键字)


8、注释

在 Python3 中,注释不会影响程序的执行,但是会使代码更易于阅读和理解。

Python 中的注释有单行注释多行注释

Python 中单行注释以 # 开头,例如:

  • 单行注释 以#开头, pycharm快捷操作 CTRl+/

  • 多行注释 一般用三个单引号或者三个双引

  1. #人生若只如初见
  2. '''
  3. 我本将心向明月
  4. 奈何明月照沟渠
  5. '''
  6. """
  7. 云想衣裳花想容
  8. 春风拂槛露华浓
  9. """

10、函数input()

Python3.x 中 input() 函数接受一个标准输入数据,返回为 string 类型。

  1. a = input("input:")
  2. print(type(a))

如下图所示:不管你输入的是什么它的数据类型都是str

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号