python是动态语言(对象属性可以动态改变,删除添加..),不是强类型语言,所以和java,c/c++等强类型静态语言有不一样地方需要注意。
一:基本数据类型
变量
counter = 1 # 整型变量
miles = 1.0 # 浮点型
name = "John,h" # 字符串
str = 'Hello World!' #字符串(支持双引号,也可使用单引号)
counter=’111‘ #此时counter为string类型
从例子可以看出,python使用变量可以直接赋值使用,不需要先声明类型,在使用,同时一个变量可以指向多种类型数据,即变量在使用中在确定。
(pytthon中变量可以看作一个引用,没有类型概念。类型只是针对对象而言,变量只是对象的引用而已)
布尔类型:True、False两种值
逻辑符: and、or和not
空值:None是一个特殊的空值
常量
在Python中,通常用全部大写的变量名表示常量
但事实上PI仍然是一个变量,Python根本没有任何机制保证PI不会被改变,所以,用全部大写的变量名表示常量只是一个习惯上的用法
字符串格式化:
s1 = 'Hello {}! I am is {}.'.format('World', 'Python') s2 = 'Hello {name1}! I am is {name2}.'.format(name1='World', name2='Python') str = ("My name is %s and age is %d !" % ('Tom', 18))
运算符
a = 2,b = 3
c = a**b //2的3次方幂运算
/除法计算结果是浮点数,即使是两个整数恰好整除,结果也是浮点数
10/5 ->2.0
//表示整除运算
a = 10,b = 5
c = a//b
对象类型
list
list数据类型是列表:是一种有序集合,可动态add,delete,motify其中的元素
tinylist = ['123', 'john','lll','poi'] tinylist.append('haha') tinylist.insert(2,'cba') tinylist.remove('john') tinylist.pop(1) # 删除索引为1位置元素 tinylist.pop() # 删除list末尾的元素 len(tinylist) #计算元素个数,len()函数可以由于任何对象
tuple
元组:tuple和list非常类似,但是tuple一旦初始化就不能修改,在定义的时候,tuple的元素就必须被确定下来
tu=(1, 2,3,4,5,6)
注意,tt=(1)不表示元组,因为括号()既可以表示tuple,又可以表示数学公式中的小括号,这就产生了歧义
只有1个元素的tuple定义时必须加一个逗号,,来消除歧义,例:tt = (1,)
dict
字典:dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储
如果key不存在,dict就会报错 KeyError: 'xxx'
tinydict = {'name': 'john', 'code': 6734, 'dept': 'sales'} print(dict['one']) # 输出键为'one' 的值 print(dict[2]) # 输出键为 2 的值 print(tinydict) # 输出完整的字典 print(tinydict.keys()) # 输出所有键 print(tinydict.values()) # 输出所有值 print([value for value in tinydict.values()]) for k, v in tinydict.items(): # 同时迭代key和value print('key='+k+'value='+v)
tinydict.get('1')
tinydict.get('1',-1)
set
set和dict类似,也是一组key的集合,但不存储value
s = set([1, 2, 3])
条件判断
num = 3 if num >= 10: print('more than 2 bit num') else: print('1 bit num') num = 3 if num >= 100: print('3 bit num') elif num >= 10: print('2 bit num') else: print('1 bit num')
# 循环
for letter in 'Python': #遍历字符串内每个字符
print ('current letter :'+letter)
fruits = ['banana', 'apple', 'mango']
for fruit in fruits: # 通过直接取值输出
print ('fruit name :'+fruit)
for index in range(len(fruits)):#通过遍历索引输出
print ('fruit name :'+ fruits[index])
数据集(一定范围内的数值)
通过range()生产数据集
for num in range(10,50): for i in range(2,num): if num % i == 0: j = num / i print ('%d = %d * %d' % (num,i,j)) break else: print(num+'是一个质数')
切片[]应用
1,用于string
str = 'Hello World!'
print(str[0]) # 输出字符串中的第一个字符
print(str[2:5]) # 输出字符串中第三个至第五个之间的字符串
print(str[2:]) # 输出从第三个字符开始的字符串
2,用于list
lst = ['hello', 88, 2.23, True, 10]
lst[1:3] # 取出第二个至第三个的元素
lst[2:] # 取出从第三个开始至列表末尾
lst[-2:] #倒数第二个,后2个元素
lst[::5] #每隔5个元素取一个,正序
lst[::-2] #倒序每隔2个元素取出一个
列表生成式:
# 筛选出仅偶数的平方
[x * x for x in range(1, 11) if x % 2 == 0]
# 输出[4, 16, 36, 64, 100]
# 两层循环,生成全排列
[m + n for m in 'ABC' for n in 'XYZ']
# ['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']