变量和简单类型

变量和简单类型

1. 单行注释和多行注释

python用井号(#)表示单行注释;
用三个单引号或者三个双引号进行多行代码注释。

2.变量
2.1 python是弱类型语言

弱类型语言的两个典型特征:

  • 变量无须声明即可直接赋值:对一个不存在的变量赋值就相当于定义了一个新变量;
  • 变量的数据类型可以动态改变:同一个变量可以一会儿被赋值为整数值,一会儿被赋值为字符串。
2.2 使用print函数输出变量

print()函数的详细语法格式:
print(value, ..., sep=' '', end='\n', file=sys.stdout, flush=False)

  1. print()函数输出多个变量时默认用空格分开,可通过设置sep参数。
  2. print()函数输出之后总会换行,因为end参数的默认值为“\n”,可设置end参数
  3. file参数的默认值是 sys.stdout,代表系统标准输出,也就是屏幕。可将file指向一个文件。
>>> with open('endprint.txt','w') as f:
...     for i in range(5):
...             print(i, '\t', end='', file=f)
  1. flush参数用于控制输出缓存,该参数一般保持为False即可,这样可以获得较好的性能。
2.3 参数的命名规则

python需要使用标识符给变量命名,其实标识符就是用于给程序中变量、类、方法命名的符号。
在使用标识符时,需要注意如下规则:

  • 标识符可以由字母、数字、下划线(_)组成,其中数字不能打头;
  • 标识符不能是python关键字,但可以包含关键字;
  • 标识符不能包含空格。
3. 数值类型
  1. 整型:int
    python的整型数值有4中表示形式:

    • 十进制形式:最普通的整数就是十进制形式的证书。
    • 二进制形式:以0B或者0b开头的整数
    • 八进制形式:以0O或者0o开头的整数
    • 十六进制形式:以0X或者0x开头的整数
  2. 浮点型:float
    python的浮点数有两种表示形式:

    • 十进制形式:就是平常简单的浮点数,如5.12
    • 科学计数形式:例如5.12e2
  3. 复数
    复数的虚部用j或者J表示。

4. 字符串入门

python要求字符串必须使用引号括起来。

  1. 字符串和转义字符
    如果字符串内容本身包含了单引号或双引号,就需要进行特殊处理:
  • 使用不同的引号将字符串括起来
  • 对引号进行转移。
  1. 拼接字符串
    如果直接将两个字符串紧挨着写在一起,python会自动拼接它们。
>>> s1 = "a1""a2"
>>> print(s1)
a1a2
  1. repr和字符串
    python不允许直接拼接数值和字符串,程序必须先将数值转换成字符串。可以使用str()或repr()函数。

str()和repr()函数都可以将数值转换成字符串,其中str本身是python内置的类型(和int、float一样),而repr()则只是一个函数。
repr还有一个功能,它会以python表达式的形式来表示值。

带引号的字符串——就是字符串的python的表达式形式。

  1. 使用input获取用户输入
    由于input()函数总会将用户输入的内容放入字符串中,因此用户可以输入任何内容,input()函数总是返回一个字符串。

  2. 长字符串

  • 使用三个引号括起来的长字符串
  • python允许使用转义字符(\)对换行符进行转义,转义之后的换行符不会“中断”字符串。
  1. 原始字符串
    由于字符串中的反斜线都有特殊的作用,因此当字符串中包含反斜线时,则需要对其进行转义。
# 这样的路劲是不行的
# path = 'C:\monica\python'

# 正确的写法
path = 'C:\\monica\\python'
# 也可以借助原始字符串来解决
path_r = r'C:\monica\python'

原始字符串以“r”开头,原始字符串不会把反斜线当成特殊字符。

如果原始字符串中包含引号,程序同样需要对引号进行转义,但此时用于转义的反斜线会变成字符串的一部分。

>>> s3 = r'"I\'m Peter",said Peter.'
>>> print(s3)
"I\'m Peter",said Peter.

如果要在原始字符串的结尾处包含反斜线,方法有二:

  • 不使用原始字符串,二用长字符串写法(三引号字符串);
  • 将反斜线单独写。
# 用长字符写法
>>> s3 = '''"I\'m Peter",said Peter.\\'''
>>> print(s3)
"I'm Peter",said Peter.\

>>> s3 = r'"I\'m Peter",said Peter.\' # 此处会引发SyntaxError

# 反斜线也变成字符的一部分
>>> s3 = r'"I\'m Peter",said Peter.\\'
>>> print(s3)
"I\'m Peter",said Peter.\\

#####单独写#####
>>> s3 = r'"I\'m Peter",said Peter.''\\'
>>> print(s3)
"I\'m Peter",said Peter.\
  1. 字节串(bytes)
    将一个字符串转换成bytes对象,有如下三种方式:
  • 如果字符串内容都是ASCII字符,则可以通过直接在字符串之前添加b来构建字节串值
  • 调用bytes()函数(其实是bytes的构造方法)将字符串按指定字符集转换成字节串,如果不指定字符集,默认使用UTF-8字符集。
  • 调用字符串本身的encode()方法将字符串按指定字符集转换成字节串,如果不指定字符集,默认使用UF-8字符集。
>>> b1 = b'hello'
>>> b2 = bytes('say something',encoding='utf-8')
>>> b3 = "speak in 中国话".encode('utf-8')
>>> print(b1,b2,b3,sep='\n')
b'hello'
b'say something'
b'speak in \xe4\xb8\xad\xe5\x9b\xbd\xe8\xaf\x9d'
5. 深入使用字符串
  1. 转义字符
    \b \n \r \t " ’ \

  2. 字符串格式化

>>> name = 'Marry'
>>> print('Hello, %s.' % name)
Hello, Marry.

上面print函数包含三个部分:格式化字符串(包含一个‘%s’占位符)、‘%’分隔符、变量或表达式

占位符的格式是:%[标志(如-+0)][最小宽度(如6)][精度值(如.3)][转换说明符(如dioxXeEfFgGCrs)]

>>> v1 = 3.00001243566743
>>> print('%8.3f' % v1)     #     3.000
>>> print('%08.3f' % v1)   #0003.000
>>> print('%+08.3f' % v1) #+003.000

>>> name = 'ascsfagga'
>>> print('%.3s' % name)
asc
>>> print('%10.3s' % name)
       asc
  1. 序列相关方法
  • 根据索引获取字符串中的字符,如:s[index]
  • 使用范围获取字符串中间的“一段”,如:s[3:5]
  • 支持用in运算符判断是否包含某个子串
  • 用内置的len()函数获取字符串的长度
  • 使用全局内置的min()和max()函数获取字符串中最小字符和最大字符
  1. 大小写相关的常用方法
  • title():将每个单词的首字母改为大写
  • lower():将整个字符串改为小写
  • upper():将整个字符串改为大写
  1. 删除空白的常用方法
  • strip():删除字符串前后的空白
  • lstrip():删除字符串前面(左边)的空白
  • rstrip():删除字符串后面(右边)的空白
    如果方法传入指定的参数,则可删除该字符串指定位置的字符。
>>> s = 'i think you are right'
>>> print(s.strip('iht'))
' think you are rig'
  1. 查找、替换相关方法
  • startswith():判断字符串是否以指定子串开头
  • endswith():判断字符串是否以指定子串结尾
  • find():查找指定子串在字符串中出现的位置,如果没有找到指定子串,则返回-1
  • index():查找指定子串在字符串中出现的位置,如果没有找到指定子串,则引发ValueError错误
  • replace():使用指定子串替换字符串中的目标子串
  • translate():使用指定的翻译映射表对字符串执行替换
>>> s = 'you may say thankyou very much.'
>>> print(s.find('you'))
0
>>> print(s.find('you',5))
17
>>> print(s.index('you',5))
17
>>> print(s.replace('you','xxx'))
xxx may say thankxxx very much.
>>> table = {97:945, 98:946, 116:964}
>>> print(s.translate(table))
you mαy sαy τhαnkyou very much.

str的translate()方法需要定义一个翻译映射表,这需要记住所有字符的编码。而str的maketrans()方法,只需要将要映射的所有字符作为maketrans()方法的第一个参数,将所有映射的目标作为maketrans()方法的第二个参数即可。

>>> table1 = str.maketrans('abc','123')
>>> print(table1)
{97: 49, 98: 50, 99: 51}
>>> print(s.translate(table1))
you m1y s1y th1nkyou very mu3h.
7. 分割、连接方法
  • split():将字符串按指定分割符分割成多个短语
  • join():将多个短语连接成字符串
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值