python 学习第二天
由于换了博客,第一篇没有在博客园写,写在了开源中国上,链接地址为http://my.oschina.net/u/254063/blog/719289,大家有兴趣可以看看
一, python 数据类型
1,数字
这就不具体解释了,数字中包含整数(int),浮点数(float),复数(complex)这三大类型
2,字符串
字符串就是这样,"hello world"
3,布尔型
和其它语言一样,布尔型就两个值,0和1,及表示true和false,布尔型一般应用在判断语句中
二,python 运算符

比较运算:

赋值运算:

逻辑运算:

成员运算:

身份运算:

位运算:

2,运算符优先级

三,python模块初识:
1,python的模块是指事先写好的一些代码做封装,然后再通过import 语句导入到python 脚本中,加以应用,从而避免了代码重复,另外也提高了开发效率。
python 导入模块示例
import os
print(os.getcwd())
2,os模块总结
(1),os.name()输出字符串指示正在使用的平台。如果是window 则用'nt'表示,对于Linux/Unix用户,它是'posix'。
(2),os.getcwd() 函数得到当前工作目录,即当前Python脚本工作的目录路径。
(3),os.listdir() 返回指定目录下的所有文件和目录名。
(4),os.remove() 删除一个文件。
(5),os.system() 运行shell命令。
(6),os.path.split() 函数返回一个路径的目录名和文件名。
3,system模块总结
(1),sys.path 查找模块所在目录的目录名列表。
(2),sys.argv 命令行的参数,包括脚本名称。
四,字符编码转换
下面一张图很好的解释了python中的字符编码转换,即从string 转换到二进制用encode,从二进制转换到string用decode,其实也可以理解为编码和解码,不过需要注意的是,在编码时要告诉编码函数自己现在的字符编码,解码时需要告诉自己要解到哪种字符编码
name="ll1234file中"
a=name.encode('utf-8')
name=a.decode('utf-8')
print(a)

五,python列表
1,列表是Python中最基本的数据结构。列表中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推。列表是可变的,即可以修改列表的内容
[a,b,c,d] 像这样的形式就是一个列表,其中a字符的位置或者说a字符的索引为0
2,列表的基本操作,
(1)读取列表的长度len()
x=["name","back","file","head"]
a=len(x)
print(a)
(2)读取列表的值,修改列表的值
x=["name","back","file","head"]
a=x[0]
print(a)
x[1]="find"
print(x)
(3)在列表中插入值,删除列表中的某个值
append方法是在列表的末尾插入字符,insert可指定位置插入,pop不加任何参数的时候默认删除最后一个值,有参数时,删除指定位置的值,其实append(),pop()是两个相反的操作,类似于如栈和出栈
x=["name","back","file","head"]
x.append("find")
x.insert(1,"happy")
x.remove("back")
print(x)x.pop()
print(x)
x.pop(1)
print(x)
(4)将两个列表合并
x=["name","back","file","head"]
y=["","",""]
x.extend(y)
print(x)
(5)统计列表中某个元素的数量,获取列表中某个元素的下标
x=["name","back","file","head","name","name"]
print(x.count("name"))
3 print(x.index("name"))
(6)循环读取列表中的值
x=["name","back","file","head","name","name"]
for i in range(len(x)):
print(x[i]
(7)列表的copy
x=["name","back","file","head","name","name"]
y=x.copy()
print(y)
(8)深拷贝和浅拷贝
在python语言中,copy有两种方法,一种如上面代码,这属于浅拷贝,下面的例子就能看出浅拷贝的问题,我们可以看到当x列表中的["1","2"]元素,单独改变某个值得时候,y列表中对应的元素值也做了相应的修改,像这样的copy我们称之为浅拷贝
x=["name","back","file",["",""],"name","name"]
y=x.copy()
x[3][0]=""
print(x)
print(y)
再来看看深拷贝,从结果中我们可以看出单独改变x中["1","2"]的某个元素的时候,y列表是不受任何影响的,这样的拷贝我们称之为深拷贝
import copy
x=["name","back","file",["",""],"name","name"]
y=copy.deepcopy(x)
x[3][0]=""
print(x)
print(y)
六,元组
1,元组是python中的另一种数据结构,元组是以()括起来的,元组的位置或者说是索引和列表的一样,都是从0开始的,元组和列表最大的不同在于,元组是不可变的,是不能被修改的 2,元组的基本操作
(1)统计元组中某个元素的数量
x=("name","back","file","head","name","name")
print(x.count("name"))
(2)求某个元素的索引,如果有重复元素,index的值取第一个元素的索引值
x=("name","back","file","head","name","name")
print(x.index("name"))
七,切片
先从原理上分析切片运算:list的切片,内部是调用__getitem__,__setitem__,__delitem__和slice函数。而slice函数又是和range()函数相关的。下面的一些列子展示了切片对列表或者元组的操作,x[2:4]表示从x列表的索引为2的元素读取,到索引为4的元素之前的范围,也就是索引为2,3的两个元素,并不包括索引为4的元素,y[::2]表示整个列表,已2为单位作为步长输出,也就是每隔1个位置输出该元素
x=('','','','','',''),
y=['','','','','','']
print(x[2:4])
print(y[::2])
切片中的范围也可以为负数,表示从列表或者元组的后面算起,输出相应位置的元素
y=['1','2','3','4','5','6']
print(x[-3:-1])
print(y[-5:-1:2])
八,字典
字典是python中的另外一种数据结构,它的形式是以{}封闭,里面包括key,value键值对,如{"name":"jack"},它的特性是无序的,而且key是唯一的,不可变的,例如{["name","number"]:"jack"} 像这样的形式就会报错,因为key为一个列表,列表是可变的
对于字典的操作方法,有如下,
(1) x.items()读取x字典中的所有值,x.keys()读取x字典中的所有key,x,get("name")获取字典中name这个key所对应的值,x["salary"]="800",再x字典中插入新的key,value,因为字典是无序的,像这种写法,最终打印出来x salary所对应的键值对,并不一定在最后一个位置
x={"name":"jack","number":"","address":"beijing"}
print(x.items())
print(x.keys())
print(x.get("name"))
x["salary"]=""
print(x)
(2) 删除字典中的某个键值,清空整个字典
x={"name":"jack","number":"","address":"beijing"}
x.pop("name")
print(x)
x.clear()
print(x)
(3)修改字典中有个键值对的值,设置键值对的默认值x["name"]="alex",将字典中"name"原有的值jack修改为了alex。setdefault()方法为字典设置默认值
如果字典中本身包含这个键值对,那么setdefault()方法不会修改原来的键值对,如果字典中没有这个键值对,那么将会以新的键值对写入字典中。
x={"name":"jack","number":"","address":"beijing"}
x["name"]="alex"
x.setdefault("name","chen")
print(x)
x.setdefault("salary","")
print(x)
python 学习第二天的更多相关文章
- python学习第二讲,pythonIDE介绍以及配置使用
目录 python学习第二讲,pythonIDE介绍以及配置使用 一丶集成开发环境IDE简介,以及配置 1.简介 2.PyCharm 介绍 3.pycharm 的安装 二丶IDE 开发Python,以 ...
- python学习第二次笔记
python学习第二次记录 1.格式化输出 name = input('请输入姓名') age = input('请输入年龄') height = input('请输入身高') msg = " ...
- Python学习-第二天-字符串和常用数据结构
Python学习-第二天-字符串和常用数据结构 字符串的基本操作 def main(): str1 = 'hello, world!' # 通过len函数计算字符串的长度 print(len(str1 ...
- python学习第二天 -----2019年4月17日
第二周-第02章节-Python3.5-模块初识 #!/usr/bin/env python #-*- coding:utf-8 _*- """ @author:chen ...
- python学习第二天第一部分
备注:写程序不能写重复性的代码 学习内容:数据类型.for循环.while循环.字符编码.文件处理 一.for循环 1.简单的for循环 for i in range(10): # 此处意思为:循环r ...
- Python学习第二节——基础知识
# !/usr/bin/edv python 脚本语言的第一行,目的就是指出,你想要你的这个文件中的代码用什么可执行程序去运行它.# -*- coding:UTF-8 -*- 标明编码注释 ...
- Python 学习第二章
本章内容 数据类型 数据运算 表达式 if ...else 语句 表达式 for 循环 表达式 while 循环 一.数据类型 在内存中存储的数据可以有多种类型. 在 Python 有五个标准的数据类 ...
- Python 学习 第二篇:数据类型(字符串)
字符串是一个字符的.有序的.不可变的序列,用于存储基于文本的信息.字符串所包含的字符存在从左至右的位置顺序,不可以在原处(in-place)修改.Python没有C语言的字符和字符串之分,只有字符串. ...
- python学习第二天-基本数据类型常用方法
1.直入主题 python中基本的数据类型有 数字(整形,长整形,浮点型,复数) 字符串 字节串:在介绍字符编码时介绍字节bytes类型 列表 元组 字典 集合 下面我们直接将以下面几个点进行学习 # ...
随机推荐
- 一个简单实用的css loading图标
摘要 在web开发中,为了提高用户体验,在加载数据的时候都会给一个loading的提示. Html <!DOCTYPE html> <html xmlns="http:// ...
- 如何使用跨平台工具创建 NuGet 包(转)
原文地址 https://docs.microsoft.com/zh-cn/dotnet/articles/core/deploying/creating-nuget-packages 内容 对于 . ...
- [.net core]简介(转)
原文地址:https://docs.microsoft.com/zh-cn/dotnet/articles/core/ NET Core 是一个通用开发平台,由 Microsoft 和 GitHub ...
- PHP框架模板原理
PHP框架现在是一种很流行的东西了,很多朋友开发应用与网站都会选择一个PHP框架或模板了,下面我们来看看PHP框架是如何实现的吧. 本文主要来聊聊框架理论,但不针对任何一款框架,不过任何 ...
- 数据量大的数据转换成jason并显示在页面上
代码列子: public ActionResult FindUserByUserId(SysMessageDTO model) { CustomResultMsg customResult = new ...
- Ubuntu下安装QQ22013
近期闲来无事,把退役的笔记本系统换成了Ubuntu. 系统安装异常的顺利,神速的安装完成.玩弄一会发现总是缺少了点什么,呆了半天发现缺少了企鹅. 由于对Ubuntu系统不了解,安装QQ着实让我头疼了半 ...
- MVC-命名空间“System.Web.Mvc”中不存在类型或命名空间名称“Html”(是否缺少程序集引用?)
如上截图,明明引用了“System.web.mvc”,可是还出这样的错误. 解决方法: 1.右键引用的“System.Web.Mvc” 2.<复制本地>一样选择<True> 3 ...
- ObjC运行时部分概念解析(二)
上篇文章简单的说明了两个关键字究竟是什么,这里主要讲讲ObjC中各种基本内存模型 Method typedef struct objc_method *Method; struct objc_meth ...
- MySQL 优化数据库对象
一.考虑是用 procedure analyse() 函数对当前应用的表进行分析.字段类型是否可优化. 二.通过拆分提高表的访问效率. (A) 针对MyISAM表,有两种拆分方法: 垂直拆分:主码和某 ...
- [转载]tomcat的配置文件server.xml不支持中文注释的解决办法
原文链接:http://tjmljw.iteye.com/blog/1500370 启动tomcat失败,控制台一闪而过,打开catalina的log发现错误指向了conf/server.xml,报错 ...