三元运算

三元运算,是条件语句的简单的写法。如果条件为真,则返回值1,否则,返回值2。

ret = 值1 if 条件 else 值2

深浅拷贝

对于数字(int)和字符串(str)而言,赋值、深拷贝、浅拷贝都无意义,因为内存地址指向同一个。

importcopy########## 数字、字符串 #########

n1 = 123

#n1 = "i am a student"

print(id(n1))### 赋值 ##

n2 =n1print(id(n2))### 浅拷贝 ##

n2 =copy.copy(n1)print(id(n2))### 深拷贝 ##

n3 =copy.deepcopy(n1)print(id(n3))

对于字典、元祖、列表 而言,进行赋值、浅拷贝和深拷贝时,其内存地址的变化是不同的。

(1)赋值,只是创建一个变量,该变量指向原来内存地址;

(2)浅拷贝,在内存中只额外创建第一层数据;

(3)深拷贝,在内存中将所有的数据重新创建一份(排除最后一层,即:python内部对字符串和数字的优化)。

函数

在学习函数之前,写代码一直是面向过程编程,即:代码执行顺序从上到下,一段代码执行所需的功能,频繁涉及到重复内容。

为了更好的代码重用性和可读性,出现了函数和面向对象。

函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可

面向对象:对函数进行分类和封装,让开发“更快更好更强...”

def函数名(参数):

...

函数体

...

返回值

函数的定义主要有如下要点:

def:表示函数的关键字

函数名:函数的名称,日后根据函数名调用函数

函数体:函数中进行一系列的逻辑计算

参数:为函数体提供数据

返回值:当函数执行完毕后,可以给调用者返回数据。

内置函数

查看详细内容:点这里!

open函数,该函数用于文件处理

操作文件时,一般需要经历如下步骤:

打开文件

操作文件

一、打开文件:f = open("文件路径","打开模式")

打开文件的模式有:

r ,只读模式【默认】

w,只写模式【不可读;不存在则创建;存在则清空内容;】

x, 只写模式【不可读;不存在则创建,存在则报错】

a, 追加模式【可读; 不存在则创建;存在则只追加内容;】

"+" 表示可以同时读写某个文件

r+, 读写【可读,可写】

w+,写读【可读,可写】

x+ ,写读【可读,可写】

a+, 写读【可读,可写】

"b"表示以字节的方式操作

rb 或 r+b

wb 或 w+b

xb 或 w+b

ab 或 a+b

注:以b方式打开时,读取到的内容是字节类型,写入时也需要提供字节类型

二、操作

classTextIOWrapper(_TextIOBase):"""Character and line based layer over a BufferedIOBase object, buffer.

encoding gives the name of the encoding that the stream will be

decoded or encoded with. It defaults to locale.getpreferredencoding(False).

errors determines the strictness of encoding and decoding (see

help(codecs.Codec) or the documentation for codecs.register) and

defaults to "strict".

newline controls how line endings are handled. It can be None, ‘‘,

‘\n‘, ‘\r‘, and ‘\r\n‘. It works as follows:

* On input, if newline is None, universal newlines mode is

enabled. Lines in the input can end in ‘\n‘, ‘\r‘, or ‘\r\n‘, and

these are translated into ‘\n‘ before being returned to the

caller. If it is ‘‘, universal newline mode is enabled, but line

endings are returned to the caller untranslated. If it has any of

the other legal values, input lines are only terminated by the given

string, and the line ending is returned to the caller untranslated.

* On output, if newline is None, any ‘\n‘ characters written are

translated to the system default line separator, os.linesep. If

newline is ‘‘ or ‘\n‘, no translation takes place. If newline is any

of the other legal values, any ‘\n‘ characters written are translated

to the given string.

If line_buffering is True, a call to flush is implied when a call to

write contains a newline character."""

def close(self, *args, **kwargs): #real signature unknown

关闭文件pass

def fileno(self, *args, **kwargs): #real signature unknown

文件描述符pass

def flush(self, *args, **kwargs): #real signature unknown

刷新文件内部缓冲区pass

def isatty(self, *args, **kwargs): #real signature unknown

判断文件是否是同意tty设备pass

def read(self, *args, **kwargs): #real signature unknown

读取指定字节数据pass

def readable(self, *args, **kwargs): #real signature unknown

是否可读pass

def readline(self, *args, **kwargs): #real signature unknown

仅读取一行数据pass

def seek(self, *args, **kwargs): #real signature unknown

指定文件中指针位置pass

def seekable(self, *args, **kwargs): #real signature unknown

指针是否可操作pass

def tell(self, *args, **kwargs): #real signature unknown

获取指针位置pass

def truncate(self, *args, **kwargs): #real signature unknown

截断数据,仅保留指定之前数据pass

def writable(self, *args, **kwargs): #real signature unknown

是否可写pass

def write(self, *args, **kwargs): #real signature unknown

写内容pass

def __getstate__(self, *args, **kwargs): #real signature unknown

pass

def __init__(self, *args, **kwargs): #real signature unknown

pass@staticmethod#known case of __new__

def __new__(*args, **kwargs): #real signature unknown

"""Create and return a new object. See help(type) for accurate signature."""

pass

def __next__(self, *args, **kwargs): #real signature unknown

"""Implement next(self)."""

pass

def __repr__(self, *args, **kwargs): #real signature unknown

"""Return repr(self)."""

passbuffer= property(lambda self: object(), lambda self, v: None, lambda self: None) #default

closed= property(lambda self: object(), lambda self, v: None, lambda self: None) #default

encoding= property(lambda self: object(), lambda self, v: None, lambda self: None) #default

errors= property(lambda self: object(), lambda self, v: None, lambda self: None) #default

line_buffering= property(lambda self: object(), lambda self, v: None, lambda self: None) #default

name= property(lambda self: object(), lambda self, v: None, lambda self: None) #default

newlines= property(lambda self: object(), lambda self, v: None, lambda self: None) #default

_CHUNK_SIZE= property(lambda self: object(), lambda self, v: None, lambda self: None) #default

_finalizing= property(lambda self: object(), lambda self, v: None, lambda self: None) #default

View Code

三、管理上下文

为了避免打开文件后忘记关闭,可以通过管理上下文,即:

with open(‘log‘,‘r‘) as f:

...

如此方式,当with代码块执行完毕时,内部会自动关闭并释放文件资源。

在Python 2.7 及以后,with又支持同时对多个文件的上下文进行管理,即:

with open(‘log1‘) as obj1, open(‘log2‘) as obj2:pass

lambda表达式

学习条件运算时,对于简单的 if else 语句,可以使用三元运算来表示。

对于简单的函数,也存在一种简便的表示方式,即:lambda表达式。

#普通条件语句

if 1 == 1:

name= ‘wupeiqi‘

else:

name= ‘alex‘

#三元运算

name = ‘wupeiqi‘ if 1 == 1 else ‘alex‘

####################### 普通函数 #######################定义函数(普通方式)

deffunc(arg):return arg + 1

#执行函数

result = func(123)####################### lambda ######################

#定义函数(lambda表达式)

my_lambda = lambda arg : arg + 1

#执行函数

result = my_lambda(123)

递归

利用函数编写如下数列:

斐波那契数列指的是这样一个数列 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584,4181,6765,10946,17711,28657,46368...

deffunc(arg1,arg2):if arg1 ==0:printarg1, arg2

arg3= arg1 +arg2printarg3

func(arg2, arg3)

func(0,1)

python读写文件函数_Python开发【第三篇】:函数读写文件相关推荐

  1. python多线程的作用_Python多线程中三个函数的强大功能简介

    在Python多线程中有三个比较简单的函数,在实际的相关操作中你对这一实际操作是否了解?是否对其感兴趣?如果你想对Python多线程的开发与多线程程序及相关实际操作方案有所了解的话,你就可以点击以下的 ...

  2. python matplotlib函数_python matplotlib 绘制三次函数图像

    安装的是anaconda, 其中包含了numpy, scipy, matplotlib 等科学计算包 在终端打开anaconda中的python /home/qi/anaconda/bin/pytho ...

  3. python 自定义模块加密_Python开发【第一篇】Python基础之自定义模块和内置模块...

    为什么要有模块,将代码归类.模块,用一砣代码实现了某个功能的代码集合. Python中叫模块,其他语言叫类库. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代 ...

  4. Python编程:从入门到实践 第三章--函数

    Python编程:从入门到实践 第三章-函数 语法 就还是需要先记一下函数定义的语法: def Test(num):num = 12 如上,def func_name(factors): # code ...

  5. Agv、Rgv 车辆控制调度系统开发第三篇

    Agv.Rgv 车辆控制调度系统开发第三篇地图编辑器 Agv.Rgv 车辆控制调度系统开发第三篇地图编辑器 Agv.Rgv 车辆控制调度系统开发第三篇地图编辑器 前言 一.GOJS 二.使用步骤 1. ...

  6. Python开发【第三篇】:文件操作与函数

    内容概要 文件操作 初始函数 函数定义与调用 函数的返回值 函数的参数 函数进阶 函数参数--动态传参 名称空间 作用域 函数的嵌套 函数名的运用 gloabal,nonlocal 关键字 1.文件操 ...

  7. and true和if都是python语言的保留字_python自学 第三章 python语言基础之保留字、标识符与内置函数...

    一.保留字(关键字) 保留字是 python 语言中一些已经被赋予特定意义的单词,这就要求开发者在开发程序时,不能用这些保留字作为标识符给变量.函数.类.模板以及其他对象命名. Python 保留字一 ...

  8. python画梅花_Python学习笔记三:函数

    1 #!/usr/bin/env python 2 #coding:utf-8 3 4 'a test module' 5 6 __author__ = 'Sunflower' 7 8 9 ## 一. ...

  9. python工具安装教程_Python 开发工具PyCharm安装教程图文详解(新手必看)

    一.概念理解1.json.dumps()和json.loads()是json格式处理函数(可以这么理解,json是字符串) (1)json.dumps()函数是将一个Python数据类型列表进行jso ...

最新文章

  1. PostgreSQL — 数据库实例只读锁定
  2. valgrind安装使用
  3. 用户故事的扩展-新的故事类别
  4. Jzoj5429 排列
  5. 关于水晶报表的一些错误
  6. 不可摸数http://acm.hdu.edu.cn/showproblem.php?pid=1999
  7. [sharepoint]rest api文档库文件上传,下载,拷贝,剪切,删除文件,创建文件夹,修改文件夹属性,删除文件夹,获取文档列表...
  8. 查询linux信号量命令,linux下的trap命令和SIGHUP信号量详解。
  9. Oracle VM Virtual Box的安装
  10. 华为鸿蒙系统深度体验报告,堪比苹果IOS的存在!
  11. as3数据类型检查写法(is/as/typeof/in/instanceof)用法介绍
  12. 2022年第十三届蓝桥杯省赛真题及部分答案解析(Java B组)
  13. 联想服务器查看运行状态,服务器硬件批量监控工具
  14. ubuntu搜狗输入法切换快捷键fcitx设置
  15. 夏天第一图noob sky
  16. 非对称算法之RSA的签名剖析
  17. C. Get an Even String
  18. 解决安装ENVI5.3报错:the installation of MSVC_2010_SP1_x64_32bit has failed
  19. 仿真软件proteus构建LCD1602显示字符串实验
  20. html如何批量查找数字,wps文档中的全部数字怎么快速查找

热门文章

  1. 机器学习项目实战----新闻分类任务(一)
  2. docker技术之基本命令
  3. PHP 入门学习教程及进阶(源于知乎网友的智慧)
  4. Power Desiner逆向生成pdm
  5. 产品经理处理问题“五步法”模板
  6. LINQ 之 JOIN(2)
  7. HP380 G9服务器RAID划分
  8. 计算机专业教学实施,中职计算机专业教学项目的设计与实施
  9. linux ftp 150 无响应,FTP遇到150无响应
  10. 错误: 15138删除对于用户失败,数据库主体在该数据库中拥有架构,无法删除。解决方法(转)