python菜鸟教程基础入门
一、
- 可以使用’\'来连接多行。但是有括号的则不需要
a=b+\
c+\
d
a1=['a',
'b']
- 引号可以是单,双,三引号均可
二、
1. python有5个标准类型:数字,字符串,列表,元组,和字典
2. 字符串
- 获取某字符串的一段字符串可以使用[头下标,尾下标]
s='abcde'
s[1:5]
# 'bcde'
s+'rrr'#字符串加法
s
#bcderrr
3. 列表:Python中使用最频繁的类型
- 列表用
[]标识,支持[]截取,从左开始从0,从右开始为-1。列表内部支持字符,数字,字符串,甚至包含列表 +为连接操作,*为输出n次
t=['a','b','c']
t1=[:1]
# t1=['a','b']
t2=['a',20,2.3,'name']
4. python元组
- 元组用()标识,内部元素用逗号分开,元组不能二次赋值,相当于只读列表
tuple1=('a',20,'name')
tuple1[1]=3300 #!!错误,不允许改变元组的值
5. python字典
- 是除列表外,最灵活的类型,字典可以通过键来存取。字典用
{}来表示,由key和value组成
dict={}
dict['one']='I\'m one'
dict[2]='Two'
dict1={'name':'ruun','code':666,'dept':'sales'}
print(dict[2])# 'Two'
6. 数据类型转换
- 举例,其他类似
long(x)#x转换为长整数
str(x)#x转换为字符串
三、运算符
1.
%:返回除法的余数 3%2 -> 1**:返回x的y次幂 10**2 -> 100- ‘//’:返回商的整数部分 9//2 ->4
2.
- and,or,not 与,或,非
3. 判断是否在指定序列
- in
- not in
4. 身份运算符
- is #判断两个标识符是否引用自一个对象
- is not
a = 20
b = a
if ( a is b ):
print "1 - a 和 b 有相同的标识"
else:
print "1 - a 和 b 没有相同的标识"
if ( a is not b ):
print "2 - a 和 b 没有相同的标识"
else:
print "2 - a 和 b 有相同的标识"
# 修改变量 b 的值
b = 30
if ( a is b ):
print "3 - a 和 b 有相同的标识"
else:
print "3 - a 和 b 没有相同的标识"
if ( a is not b ):
print "4 - a 和 b 没有相同的标识"
else:
print "4 - a 和 b 有相同的标识"
#1 - a 和 b 有相同的标识
#2 - a 和 b 有相同的标识
#3 - a 和 b 没有相同的标识
#4 - a 和 b 没有相同的标识
四、
- python没有switch语句,判断多条需要elif;判断多个条件,可以使用or
if num>0 and num <10:
print('1')
elif num==0:
print('0')
五、循环语句
- while
while (c<5):
pass
else:
pass
- for
a=['a','b','c']
for i in a:
print(i)# 'a' 'b' 'c'
for i in range(len(a))
print(a[i])# 'a' 'b' 'c'
六、
- break,continue 语句与c++中作用相同,用于跳出循环
- pass语句为空语句,保持程序完整
七、字符串
- 字符串支持 in, not in 访问
- print输出时,格式化字符串或者数字
- 使用三引号,可实现所见即所得,不用再在内容内部使用转义字符
print ('I am %s and age is %d'%('Myy',18))
a='''I / % * '''
- %s-字符串
- %d-整数
- %c-字符
- %f-浮点数,可以指定小数点后精度
八 列表
利用append更新列表
del删除列表某元素
del list1[2]支持in,not in操作
支持len()操作
list1[-1],表示倒数第一个元素
cmp(l1,l2)比较
len(l1)
max(l1)最大
min(l1)
list(seq)元组转为列表
list.append
list.count(obj)统计某个元素在list中出现次数
list.extend(seq)一次追加另一个序列的多个值
list.index(obj)找到该值并返回其索引
list.insert(index,obj)插入
list.pop[index=2])移除一个元素,默认是最后一个
list.remove(obj)移除某个值的第一个匹配项
list.reverse()反向表中元素
九、元组
- 元组与列表类似,不同之处在于元组不可修改,元组使用
(),而列表用[] - 元组中只包含一个元素时,需要在元素后面添加逗号。
tuple=(50,) - 可以通过索引访问元组值,可以进行截取,组合,但是不能修改其中的值
- 元组的某一个值不可以删除,但是允许del语句删除整个元组
t1=('a',3,'aaa')
t2=(4,)
t3=t1[2] #'aaa'
t4=t1+t2 # 'a',a,'aaa',4
del t4
print(t4) #报错!!
- 元组的运算符:支持in 遍历;
len((1,2,3)) # 3
t1=(1,)+(3,4) # (1,3,4)
t2=('A')*4 #('A','A','A','A')
for x in t2: print(x)
- 元素截取
L=('spam','Spam','SPAM')
L[2] #'SPAM'
L[-2] #'Spam'
L[1:] #'Spam','SPAM'
- 元组内置函数
- cmp(t1,t2) #比较
- len(tuple)
- max(tuple) 返回最大值
- min(tuple)
- tuple(seq) 将列表转为元组
十、字典
- 字典值的访问,直接通过索引key
dict={'name':'Zara','Age':7,'Class':'First'}
print(dict['name'])
- 字典里的内容可以通过key索引修改
- 支持删除某一元素、清空字典、删除整个字典
dict={'Name':'nancy','Age':4,'Class':'First'}
del dict['Name'] #删除某一条目
dict.clear() #清空字典
del dict #删除字典
- 字典内置函数
- cmp(d1,d2)
- len(d1)
- str(d1) # 输出字典可打印的字符串表示
- type(variable) #返回输入的变量类型
- dict.copy()#返回一个字典的浅复制
- dict.has_key(key)#如果键在字典里返回true,否则返回false
- dict.items() #以列表返回可遍历的(键,值)元组数组
- dict.update(d2)# 将d2的值更新到dict中
- dict.values() #以列表返回一个字典所有的值
- dict.keys() #以列表返回一个字典所有的键
- pop(key[,defalut]) 删除字典给定键key所对应的值,返回被删除的值
- popitem() 返回并删除字典最后一对键合值
十一、时间和日期
- 这里只说操作,具体实现用到再看该链接
- 获取当前时间
- 获取格式化好的时间
- 自定义格式化时间
- 获取某月日历
import time
t=time.locatime(time.time())
print(t)
# time.struct_time(tm_year=2016, tm_mon=4, tm_mday=7, tm_hour=10, tm_min=3, tm_sec=27, tm_wday=3, tm_yday=98, tm_isdst=0)
....
十二、
1. python没有值传递或者引用传递的定义,但是可分 可变对象和不可变对象。python的列表和字典就是可变对象,在函数内部修改后,函数外部也会随着修改,其他诸如字符串,数字等则不可变
def f1(a):
a=110
def f2(list1):
list1.append([1,2,3])
b=0
list2=['a',1]
print(f1(b))# 0
print(f2(list2))#['a',1,1,2,3]
2.关键字参数,可以不按照顺序来传入参数,但要保持关键字相同
def f1(name,age):
print('name: ',name)
print('age: ',age)
f1(age=19,name='M')
# name: M
# age: 19
3.默认值参数,没有输入则打印默认值
def f1(age=30,name):
print('name:',name)
print('age:',age)
f1(name='miki')
# 'name:' miki
# 'age:' 30
f1(age=50,name='Zara')
# 'name:' Zara
# 'age:' 50
4.不定长列表或字符,数字等;不定长字典*args,**kwarg
def f1(name,*list):
print(name)
for i in list:
print(i)
a=['a','b','c']
f1(name='Zara',a)
f1(name='Amili',1,2)
#--------------
def f1(**kwarg):print(kwarg)
f1(x=1,y=3,name='A')
# {'x':1,'y':3,'name':'A'}
5.lambda表达式
- 基本语法:lambda[arg1,agr2,…]:expression
sum=lambda arg1,arg2:arg1+agr2
print(sum(10,20))#30
6. 全局变量和局部变量
- 注意定义的全局变量在函数内部变为,局部变量
total = 0 # 这是一个全局变量
# 可写函数说明
def sum( arg1, arg2 ):
#返回2个参数的和."
total = arg1 + arg2 # total在这里是局部变量.
print "函数内是局部变量 : ", total
return total
#调用sum函数
sum( 10, 20 )
print "函数外是全局变量 : ", total
十三、
import math后,调用其中的函数时需要match.sum(1,2),加前缀- ‘from A import B’,使用同上
B(a,a)orB.fun() from A import*, 一次将所有A中内容引入
十四、
1. 读取键盘输入raw_input()、input()
两者区别就是input支持输入表达式进行计算
2. 文件的读写具体操作,用到时再参考该链接
str=raw_input("Input your words:")
print(str)
# Input your words: 111
# 111
str=('Input')
print(str)
# Input [x*4 for i in range(2)]
# [0,4]
十五、File操作
- open(file,mode=‘r’),必须搭配close();mode为打开模式
mode 参数有
- x: 写模式,新建一个文件,如果该文件已经存在,则报错
- +:打开文件,可读可写
- r:只读形式,文件中指针放在文件开头
- r+:读写文件,指针在文件开头
- w:只写,如果文件已存在,则打开,并从头开始编辑,原有内容会被删除。如果该文件不存在,创建新文件
- w+:读写,如果文件已存在,则打开,并从头开始编辑,原有内容会被删除。如果该文件不存在,创建新文件
- a:追加文件,指针在文件尾。文件不存在则创建
- a+:追加,可读可写,文件指针会在文件结尾
*…以及一些二进制形式处理的模式
- file常用函数
- f.flush() 刷新文件内部缓冲
- f.close() 关闭文件
- f.next() 返回文件下一行
- f.readline() 读取整行,包括’\n’
- f.readlines() 读取所有行,并返回列表
- f.tell() 返回文件当前位置
- f.writelines(sequences) 向文件写入一个序列字符串列表,需要自己手动加入每行的换行符
十六 python常用内置函数
abs()绝对值divmod(a,d)输出除法结果的商和余数enumerate()将一个可遍历的数据对象,如列表,元组,组合为一个索引序列,同时给出数据和数据下标
>>>seq = ['one', 'two', 'three']
>>> for i, element in enumerate(seq):
... print i, element
...
0 one
1 two
2 three
math.pow()求幂
import math
print(math.pow(3,0))# 1
print(math.pow(3,2))# 9
- map(fun,iterable)用法1,根据提供的函数对指定序列做映射
- map用法2,对某数据里的字符串进行字典式映射
# 1.
def f1(a):
a*4
list2=map(f1,[1,2,3,4])
list3=map(lambda x:x*4,[1,2,3,4])
list4=map(lambda x,y:x*y,[1,2,3,4],[2,2,2,3])
# list2=[4,8,12,16]
# list3=[4,8,12,16]
# list4=[2,4,6,12]
# 2.
MAP_SEX={'male':1,'female':0}
# Sex
# 0 male
# 1 female
data.map(MAX_SEX)
# Sex
# 0 1
# 1 0
eval()执行一个字符串表达式,并返回表达式的值
x=7
eval('x*3')
>>21
zip将可迭代的对象作为参数,将对象中的元素打包为一个个元组,返回元组组成的列表
a=[1,2,2]
b=[4,5,6]
z=zip(a,b)
#c=[(1,4),(2,5),(2,6)]
set创建一个无序不重复元素集,可删除重复数据,还可进行交集,差集,并集操作等id()返回对象的内存地址- 'sorted()'对列表内容进行排序,可以定义比较的规则
a=[3,4,1]
L=[('a',1),('c'.3),('e',0),('d',9)]
sorted(L,lambda x:x[1])#按照列表里的元素的第二个内容排序
#L=[('e',0),('a',1),('c'.3),('d',9)]
python菜鸟教程基础入门的更多相关文章
- 深度学习入门者的Python快速教程 - 基础篇
5.1 Python简介 本章将介绍Python的最基本语法,以及一些和深度学习还有计算机视觉最相关的基本使用. 5.1.1 Python简史 Python是一门解释型的高级编程语言,特点是简单明 ...
- SQLAlchemy 教程 —— 基础入门篇
SQLAlchemy 教程 -- 基础入门篇 一.课程简介 1.1 实验内容 本课程带领大家使用 SQLAlchemy 连接 MySQL 数据库,创建一个博客应用所需要的数据表,并介绍了使用 SQLA ...
- python菜鸟教程学习3:基础语法
菜鸟教程对应网址:https://www.runoob.com/python3/python3-basic-syntax.html 编码:python3用UTF-8编码,所有字符串都是unicode字 ...
- VS2013中Python学习笔记[基础入门]
前言 在上一节中简单的介绍了在VS2013中如何进行开发Hello World,在VS2013中进行搭建了环境http://www.cnblogs.com/aehyok/p/3986168.html. ...
- python菜鸟教程学习10:数据结构
列表方法 list.append(x):把一个元素添加到列表的结尾,相当于 a[len(a):] = [x]. list.extend(L):通过添加指定列表的所有元素来扩充列表,相当于 a[len( ...
- python菜鸟教程学习:数据结构
列表方法 list.append(x):把一个元素添加到列表的结尾,相当于 a[len(a):] = [x]. list.extend(L):通过添加指定列表的所有元素来扩充列表,相当于 a[len( ...
- 给深度学习入门者的Python快速教程 - 基础篇
实在搞不定博客园的排版,排版更佳的版本在: https://zhuanlan.zhihu.com/p/24162430 Life is short, you need Python 人生苦短,我用Py ...
- 给深度学习入门者的Python快速教程 - 基础篇(转)
原文:https://zhuanlan.zhihu.com/p/24162430 5.1 Python简介 本章将介绍Python的最基本语法,以及一些和深度学习还有计算机视觉最相关的基本使用. 5. ...
- Python学习之路【第一篇】-Python简介和基础入门
1.Python简介 1.1 Python是什么 相信混迹IT界的很多朋友都知道,Python是近年来最火的一个热点,没有之一.从性质上来讲它和我们熟知的C.java.php等没有什么本质的区别,也是 ...
随机推荐
- web自动化 下拉框、切换到新窗口
一.下拉框 相信大家在手动测试web页面时,遇到过下拉框吧,那进行web自动化测试时,如何操作下拉框,且看下文 1.selenium中提供了方法,先导入Select方法 from selenium.w ...
- csust T1097 “是时候表演真正的技术了” 题解(虚点跑最短路)
题目链接 题目大意 给你n个点m条路,以及k个宝藏点,q次查询要你求出距离这个点最近的宝藏点的距离 题目思路 一个套路题,建立虚点与k个点连一个权值为0的边,跑最短路即可 注意边多了4000条 代码 ...
- redis cluster可用性测试
上一节,我们用三台redis组成了cluster,现在我们停掉一台试试: 比较奇怪的是,在停掉其中一台服务器之前建立的链接仍然可以正常执行命令,当我们断开重连时,命令就都被拒绝了: 关联知识: 什么时 ...
- python应用(4):变量与流程
程序是什么?就是一堆代码啰.但是代码是有组织而来的,不是凭空堆砌出来的.有一个"古老"的说法:程序=数据结构+算法,意思是,程序是由一些数据结构(数据的组织结构)加上某些算法而形成 ...
- Django----Serializer序列化
serializer的两大特征 1.校检数据 2.序列化 首先创建apps/Serializer.py 在序列化里面导包 from rest_framework import serializers ...
- 使用SpringSecurity Oauth2.0实现自定义鉴权中心
Oauth2.0是什么不在赘述,本文主要介绍如何使用SpringSecurity Oauth2.0实现自定义的用户校验 1.鉴权中心服务 首先,列举一下我们需要用到的依赖,本文采用的是数据库保存用户信 ...
- 因为一个Docker问题,我顺手整理从安装到常用命令操作手册
今天,自己写了一部分业务代码,是常规代码的另外一种方式,不能在公司的服务器上测试,就自己在PC端搭建了一套和公司集群一样的模板,因为公司的业务模块的测试有单独的服务器(这一块还是我很稀罕的),但是,第 ...
- PyQt(Python+Qt)学习随笔:windows下使用pyinstaller将PyQt文件打包成exe可执行文件
专栏:Python基础教程目录 专栏:使用PyQt开发图形界面Python应用 专栏:PyQt入门学习 老猿Python博文目录 在<windows下使用pyinstaller将多个目录的Pyt ...
- PyQt(Python+Qt)学习随笔:视图中类QAbstractItemView的dragDropOverwriteMode属性不能覆盖写的问题
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 在<PyQt(Python+Qt)学习随笔:视图中类QAbstractItemView的dra ...
- PyQt(Python+Qt)学习随笔:部件的minimumSize、minimumSizeHint之间的区别与联系
1.minimumSize是一个部件设置的最小值,minimumSizeHint是部件Qt建议的最小值: 2.minimumSizeHint是必须在布局中的部件才有效,如果是窗口,必须窗口设置了布局才 ...