python数据类型,格式话输出
一.程序交互
name = input(“你的名字是:”) #用户输入,输入的任何东西都存储成str(字符串类型)的形式 二.注释的重要性 以后动辄几千行代码的时候,回过头再去看的时候,发现自己都看不懂了,在工作中还会大家一起合作完成代码,不写注释的话,更难以交流了。
单行注释直接在句首写上#就好了
多行注释可用快捷键ctrl+/,或者用三个引号括起来''' 99999999
12345789
'''
#1. 不用全部加注释,只需要在自己觉得重要或不好理解的部分加注释即可
#2. 注释可以用中文或英文,但不要用拼音 三.基本数据类型(查看数据类型的方法type())

1.数字类型
int(整型)
在32位机器上,整数的位数为32位,取值范围为-2**31~2**31-1,即-2147483648~2147483647
在64位系统上,整数的位数为64位,取值范围为-2**63~2**63-1,即-9223372036854775808~9223372036854775807
long(长整型)
跟C语言不同,Python的长整数没有指定位宽,即:Python没有限制长整数数值的大小,但实际上由于机器内存有限,我们使用的长整数数值不可能无限大。
注意,自从Python2.2起,如果整数发生溢出,Python会自动将整数数据转换为长整数,所以如今在长整数数据后面不加字母L也不会导致严重后果了。
注意:在Python3里不再有long类型了,全都是int
float(浮点型)(精度限制17位,小数点后16位)
定义:salary=3.1 #salary=float(3.1)
用于标识:工资,身高,体重,
############ if a.isdigit(): # 判断是不是a数字
2.字符串类型
python中,加了引号(单引号可以,双引号也可以,三个单引号也可以)的字符都叫字符串
你需要考虑单双的配合(特殊情况,其他情况下随意)
msg = "My name is Alex , I'm 22 years old!"
多引号什么作用呢?作用就是多行字符串必须用多引号
字符串拼接:
字符串可以进行相加和相乘的操作
>>> a='hello'
>>> b=' world'
>>>
>>> a + b
'hello world'
>>> res=a + b
>>> print(res)
hello world
>>> a*3
'hellohellohello'
a.isdigit() # 判断一字符串是否只包括数字
a.replace('old','new',max) # old被替换的字符,new换成的字符,max最大替换次数
a.find() # 查找是否含有字符串,是返回索引值,否者返回-1
a.count() # 统计字符出现次数
a.strip() # 删除一个字符串
a.center(10,'-') # 左右填充10位的-
a.split('a',2) # 在a出现是地方进行切片(a也没有了),切片2次
a.format()
通过关键字
1 print('{名字}今天{动作}'.format(名字='陈某某',动作='拍视频'))#通过关键字
2 grade = {'name' : '陈某某', 'fenshu': '59'}
通过位置
1 print('{1}今天{0}'.format('拍视频','陈某某'))#通过位置
2 print('{0}今天{1}'.format('陈某某','拍视频'))
a.join
>>> A = 'hello,world'
>>> ' '.join(A)
'h e l l o , w o r l d'
>>> '>'.join(A)
'h>e>l>l>o>,>w>o>r>l>d'
3.布尔类型(bool)
布尔类型很简单,就只有两个值,一个真(true),一个假(false),主要用于逻辑运算 4.列表类型(list)
创建 name = ['张三',‘王五’,‘李四’,1,2,5,4,5,4,‘李四’]
list('abc') # 结果为['a', 'b', 'c']
查询,取出 name[0] # 结果为'张三' name[-1] # 结果为'李四'
查询索引值 name.index('李四') # 结果为2,有重复的时候,只能找到第一个
查询重复出现的个数 name.count('李四') # 结果为2(个)
切片(顾头不顾尾) name[0:2] #结果为['张三','王五']
值得注意的是 name[-5:-1] # 结果为[5,4,5,4] name[-5:] # 结果才是[5,4,5,4,'李四']
中间隔一个取一个 name[7:2] # 结果为['张三','李四',2,4]
增加和修改 name.appeend('Xander') # 加到了最后面
name.insert(0,'lexi') # 插入到指定位置
修改(直接赋值就好了) name[1:3] = ‘abc’ # 批量修改‘王五’,‘李四’被修改成了'a','b','c'(中间还增加了一个)
删除 name.pop() # 删掉最后一个
name.remove('张三') # 删除索引到的第一个'张三'
del name[1] # 删掉了name[1],删除全局,可以删除任何东西
del name[1:5] # 批量删除
排序 n = ['a','c','b','f','e',1,3]
n1 = ['a','c','b','f','e']
n2 = [1,2]
n.sort() # 会报错int和str不能一起排序
n1.sort() # 会按照ASCII码表排序
反转 n.reverse()
拼接列表 n1 + n2 # 或者n1.extend(n2)
清空列表 n.clear()
copy n1 = n2 # 如果修改了n2列表中的值,n1也会一起被修改,这里和变量里面是不一样的
n1 = n2.copy() # 这个时候修改n2不会一起修改n1的值
5.元组(tuple)
"""
元组【有序不可变】
作用:存多个值,对比列表来说,元组不可变(是可以当做字典的key的),主要是用来读
定义:
与列表类型比,只不过[]换成()
""" t = ('a',) # 元祖只有一个元素时,需要加逗号, 和字符串区分开
t = ('a', 'b', 'b', 'c') # 定义一个元组
t = tuple(('a', 'b', 'b', 'c')) print(t.index('b')) # 索引出元素第一次出现的位置,还可以指定在某一范围里查找,这里默认在整个元组里查找输出1
print(t.count('b')) # 计算元素出现的次数,这里输出2
print(len(t)) # 输出远组的长度,这里输出4
print(t[1:3]) # 切片 输出('b','b')
for i in t:
print(i) # 循环打印出元组数据
6.字典(dict)
"""
字典【无序可变】
作用:存多个值,key-value存取,取值速度快
定义:
key必须唯一,必须是不可变类型,value可以是任意类型
""" # 创建:
info = {"name": "tom", "age": 18, "gender": "male"} # 本质info=dict({"name":"tom","age":18})
# info=dict(name='tom',age=18,gender='male')
# info=dict([['name','tom'],('age',18)])
# info={}.fromkeys(('name','age','gender'),None) #{'name': None, 'gender': None, 'age': None} # 增加
info['salary'] = 50000 # {'name': 'tom', 'age': 18, 'salary': 50000, 'gender': 'male'} # 删除
info.pop('age') # 根据键删除某一元素 d={'Michael': 95, 'Tracy': 85}
info.popitem() # 随机删除
info.clear() # {} # 修改
info['age'] = '' # 如果没有该key,则在字典创建新的的的key-value # 查询
info.get('age') # 根据key获取values,如果不存在返回None,这里输出75
'''
setdefault的功能
1:key存在,则不赋值,key不存在则设置默认值
2:key存在,返回的是key对应的已有的值,key不存在,返回的则是要设置的默认值
'''
print(info.setdefault('age', 50000)) #
print(info.setdefault('salary', 50000)) #
print(info) # {'age': 18, 'name': 'tom', 'salary': 50000, 'gender': 'male'} # 其他
print(len(info)) # 输出字典长度
print('age' in info) # python3 中移除了 has_key,要判断键是否存在用in for i in info:
print(i) # 循环默认按键输出 for i in info.values(): # 循环按值输出
print(i) for k, v in info.items(): # 循环按键值输出
print(k, v)
字典相关题目及答案
#创建一个字典
dic = {'k1':'v1','k2':'v2','k3':'v3'}
#1.请循环遍历出所有的KEY
for k in dic:
print(k)
#2请循环遍历出所有的value
for k in dic:
print(dic[k])
#3请循环遍历初所有的KEY和VALUE
for k in dic:
print(k,dic[k])
#4请在字典中添加一个键值对,'k4':'v4',输出添加后的字典
dic['k4'] = 'v4'
print(dic)
#5请删除字典中键值对'k1','v1',并输出删除后的字典
dic.pop('k1')
print(dic)
#6请删除字典中键'k5'对应的键值对,如果字典中不存在键'k5',则不报错,并且让其返回none
if 'k5' in dic:
dic.pop('k5')
else:
print(dic.get('k5'))
#7请获取字典中'k2'对应的值
print(dic.get('k2'))
#8请获取字典中'k6'对应的值,如果'k6'不存在,则不报错,并且让其返回Nnoe
print(dic.get('k6'))
#9现有dic2 = {'k1':'v111','a':'b'}请通过一行操作使dic2 = {'k1':'v1','k2':'v2','k3':'v3','a':'b'}
dic = {'k1':'v1','k2':'v2','k3':'v3'}
dic2 = {'k1':'v111','a':'b'}
dic2.update(dic)
print(dic2)
#10.组合嵌套题,写代码,有如下列表,按照要求实现每一个功能
lis = [['k',['qwe',20,{'k1':['tt',3,'']},89],'ab']]
#10.1.将列表lis 中的'tt'变成大写(用两种方式)
#10.1.1
print(lis[0][1][2].get('k1')[0].upper())
#10.1.2
print(lis[0][1][2].get('k1')[0].swapcase())
#10.2.将列表中的数字3 变成字符串'100'(用两种方式)
#10.2.1
print(lis)
lis[0][1][2].get('k1')[1] = ''
print(lis)
#10.2.2
lis = [['k',['qwe',20,{'k1':['tt',3,'']},89],'ab']]
dic3 = {'k1':['tt','','']}
print(lis)
lis[0][1][2].update(dic3)
print(lis)
#10.3 将列表中的字符串'1'变成数字101(用两种方式)
#10.3.1
lis = [['k',['qwe',20,{'k1':['tt',3,'']},89],'ab']]
print(lis)
lis[0][1][2].get('k1')[2] = 101
print(lis)
#10.3.2
lis = [['k',['qwe',20,{'k1':['tt',3,'']},89],'ab']]
dic3 = {'k1':['tt',3,101]}
print(lis)
lis[0][1][2].update(dic3)
print(lis)
#11 按照要求实现以下功能:
#现有一个列表li = [1,2,3,'a','b',4,'c'],有一个字典(此字典是动态生成的,你并不知道他里卖弄有多少键值对,所以
#用dic = {}模拟此字典);现在需要完成这样的操作:如果该字典没有'k1'这个键,那就创建'k1'键和其对应的值(该键对应的值设置为空列表)
#并将列表li 中的 索引为奇数的对应元素,添加到'k1'这个键对应的空列表中。如果该字典有'k1'这个键,且'k1'对应的value
#是列表类型,那就将li中的索引为奇数的对应元素,添加到'k1'这个键对应的键中
dic = {'k2':2,'k3':3}#1. dic{}字典中 没有 'k1'
#dic = {'k1':['we','tt'],'k2':2}#2 dic{}字典中有'k1'
#dic = {'k1':1,'k2':33} # 有'k1'但'k1'value 非列表
li = [1,2,3,'a','b',4,'c']
if not 'k1' in dic:
dic.setdefault('k1',[])
for i in li :
if li.index(i) % 2 == 1:
dic['k1'].append(i)
else:
if type(dic['k1']) == type([]):
for i in li:
if li.index(i) % 2 == 1:
dic['k1'].append(i)
else:
print("字典K1,VALUE 不是列表,无法追加")
print(dic)
字典习题及答案
6集合(set)
"""
集合【无序可变】
作用:去重,关系运算
定义:
1:每个元素必须是不可变类型(可hash,可作为字典的key)
2:没有重复的元素
3:无序
4:可以包含多个元素,用逗号分割,
"""
a = {1, 2, 3, 4, 5, 6, 7, 8, 9}
b = {1, 3, 9, 10, 11} a.add(10) # 添加一个元素 a.discard(1) # 删除元素1,不存在的话不报错
a.remove(1) # 删除元素1,不存在的话报错
a.pop() # 随机删除 a.update([1, 8, 34]) # 更新,没有就添加,有就不添加 # 并集
a.union(b)
a | b
# 返回一个新的集合包含a和b的所有元素 # 交集
a.intersection(b)
a & b
# 返回一个新的集合包含a和b的公共元素 # 差集
a.difference(b)
a - b
# 返回一个新的集合,包含a中的元素,但是没有b中的元素 # 对称差集
a.symmetric_difference(b)
print(a ^ b)
# 返回一个新的集合包含 a和b中不重复的元素
数据类型总结
- 【有序】: 列表,元组
- 【无序】: 字典,集合
- 【可变】:列表,字典,集合
- 【不可变】:数字,字符串,元组
- 【存单值】:数字,字符串
- 【存多值】:列表,元组,字典
四.格式化输出
利用占位符
%s就是代表字符串占位符,除此之外,还有%d,是数字占位符, 如果把上面的age后面的换成%d,就代表你必须只能输入数字啦;
%f小数
name = input('Name:')
age = input('Age:')
job = input('Job:')
hometown = input('Hometown:')
info='''
--------info of %s---------------
Name: %s
Age: %s
Job: %s
Hometown: %s
------------end------------------
'''%(name,name,age,job,hometown)
print(info)
格式化
python数据类型,格式话输出的更多相关文章
- python json.dumps()函数输出json格式,使用indent参数对json数据格式化输出
在python中,要输出json格式,需要对json数据进行编码,要用到函数:json.dumps json.dumps() :是对数据进行编码 #coding=gbkimport json dict ...
- python中json格式数据输出实现方式
python中json格式数据输出实现方式 主要使用json模块,直接导入import json即可. 小例子如下: #coding=UTF-8 import json info={} info[&q ...
- Python数据类型的内置函数之str(字符串)
Python数据类型内置函数 - str(字符串) - list(列表) - tuple(元组) - dict(字典) - set(收集) str(字符串)的一些操作 - 字符串相连方法 # 字符串的 ...
- Python——数据类型
如果是C语言,Java使用一个变量之前需要声明,数字,字符,布尔等都有特定的声明方式,前端中常用的js中都要使用var,而python中直接用就行了 比如: 虽然是这样使用,但其实是当你给一个变量赋值 ...
- python 数据类型---布尔型& 字符串
python数据类型-----布尔型 真或假=>1或0 >>> 1==True True >>> 0==False True python 数据类型----- ...
- Python 数据类型及其用法
本文总结一下Python中用到的各种数据类型,以及如何使用可以使得我们的代码变得简洁. 基本结构 我们首先要看的是几乎任何语言都具有的数据类型,包括字符串.整型.浮点型以及布尔类型.这些基本数据类型组 ...
- day01-day04总结- Python 数据类型及其用法
Python 数据类型及其用法: 本文总结一下Python中用到的各种数据类型,以及如何使用可以使得我们的代码变得简洁. 基本结构 我们首先要看的是几乎任何语言都具有的数据类型,包括字符串.整型.浮点 ...
- Python学习笔记(五)--Python数据类型-数字及字符串
Python数据类型:123和'123'一样吗?>>> 123=='123'False>>> type(123)<type 'int'>>> ...
- 【转】Python数据类型之“文本序列(Text Sequence)”
[转]Python数据类型之“文本序列(Text Sequence)” Python中的文本序列类型 Python中的文本数据由str对象或字符串进行处理. 1.字符串 字符串是Unicode码值的不 ...
随机推荐
- c++(重载等号=操作为深拷贝)
// ConsoleApplication19.cpp : 定义控制台应用程序的入口点. // #pragma warning(disable:4996) #include "stdafx. ...
- tornado设置cookie过期时间(expires time)
具体的tornado设置过期时间的东西, 我也是查资料才发现的, 现在就贴代码吧 用户登录之后, 设置cookie, 我使用set_secure_cookie的, 它默认是有个30天的过期时间, 导致 ...
- Entity Framework 6 初体验
Entity Framework中有三种模式 Code First, Model First和Database First, Code First 是在EF4中新增的模式, 也跟NHibernate等 ...
- 【转】Android android listview的HeadView左右切换图片(仿新浪,网易,百度等切换图片)
首先我们还是看一些示例:(网易,新浪,百度) 下面我简单的介绍下实现方法:其实就是listview addHeaderView.只不过这个view是一个可以切换图片的view,至于这个vie ...
- ASP.NET MVC Controller 编程所涉及到的常用属性成员
Controller (System.Web.Mvc.Controller) 1.获取路由中的各个值 Request.RequestContext.RouteData.Values["id& ...
- Javascript中对数组处理的函数汇总
数组类型是JS中非常常见的类型,而且JS里的数组与其他多数语言中的数组有所不同,它的数组里每一项可以存放任何一种类型的数据,也就是说数组的第一项放的是字符串,第二项可以放数字或对象都没问题.而且JS中 ...
- 为什么 kubernetes 天然适合微服务 (1)
此文已由作者刘超授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验 最近总在思考,为什么在支撑容器平台和微服务的竞争中,Kubernetes 会取得最终的胜出,事实上从很多角度出发 ...
- 用C语言构建一个可执行程序的流程
1.流程图 从用C语言写源代码,然后经过编译器.连接器到最终可执行程序的流程图大致如下图所示. 2.编译流程 首先,我们先用C语言把源代码写好,然后交给C语言编译器.C语言编译器内部分为前端和后端. ...
- .NET clickonce修改发布名称等
见图
- 泛型2(lambda表达式/参数绑定)
lambda 表达式: Lambda表达式完整的声明格式如下: [capture list] (params list) mutable exception-> return type { fu ...