Python基础知识入门(五)(二)

简介: 模块是一个包含所有定义的函数和变量的文件,其后缀名是.py。模块可以被别的程序引入,以使用该模块中的函数、变量等功能来完成数据处理。

二、文件操作

      open() 方法用于打开一个文件,并返回文件对象。如果该文件无法被打开,会抛出 OSError。


注意:


      使用 open() 方法一定要保证关闭文件对象,即调用 close() 方法。


      open() 函数常用形式是接收两个参数:文件名(file)和模式(mode),即open(file, mode='r')。


1.mode 参数

模式

描述

t

文本模式 (默认)。

x

写模式,新建一个文件,如果该文件已存在则会报错。

b

二进制模式。

+

打开一个文件进行更新(可读可写)。

r

以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。

rb

以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。一般用于非文本文件如图片等。

r+

打开一个文件用于读写。文件指针将会放在文件的开头。

rb+

以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。一般用于非文本文件如图片等。

w

打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。

wb

以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。

w+

打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。

wb+

以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。

a

打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。

ab

以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。

a+

打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。

ab+

以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。

2.file对象

方法

描述

close()

关闭文件。关闭后文件不能再进行读写操作。

x = open('123.txt', 'w')
x.close()

flush()

刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件,

而不是被动的等待输出缓冲区写入。

x = open('123.txt', 'w')

x.flush()
x.close()

fileno()

返回一个整型的文件描述符(file descriptor FD 整型),

可以用在如os模块的read方法等一些底层操作上。

x = open('123.txt', 'w')

y = x.fileno() ;print(y)
x.close()

isatty()

如果文件连接到一个终端设备返回 True,否则返回 False。

x = open('123.txt', 'w')

y = x.isatty() ;print(y)
x.close()

read(x)

从文件读取指定的字节数,如果未给定或为负则读取所有。

x = open('123.txt', 'r')

y = x.read(10);print(y)
x.close()

readline()

读取整行,包括 "\n" 字符。

x = open('123.txt', 'r')

y = x.readline();print(y)
x.close()

readlines()

方法用于读取所有行(直到结束符 EOF)并返回列表,

该列表可以由 for... in ... 结构进行处理。如果碰到结束符 EOF 则返回空字符串。


x = open('123.txt', 'r')


for line in x.readlines()


        line = line.strip() # 去掉空白符


        print(line)           # 读取每一行

x.close(

seek(x)

移动文件读取指针到指定位置

x = open('123.txt', 'w')

x.write('123456')

y = x.seek(3);y=3

x.close()

tell()

返回文件当前位置。

x = open('123.txt', 'w')

y = x.tell();print(y)
x.close()

truncate(x)

从文件的首行首字符开始截断,截断文件为 x 个字符,

无 x 表示从当前位置截断;截断之后后面的所有字符被删除,

其中 windows 系统下的换行代表2个字符大小。

x = open('123.txt', 'w')

x.truncate(10)

print(x.read())
x.close()

write(x)

将字符串写入文件,返回的是写入的字符长度。

x = open('123.txt', 'w')

x.write('123456')

print(x.read())
x.close()

writelines(y)

向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。

x = open('123.txt', 'w')

y = ['1\n','2\n','3\n']

x.writelines(y)
x.close()



三、面向对象

      类的定义:  用来描述具有相同的属性和方法的对象的集合。


      类的方法:类中定义的函数。


      类的变量:类变量在整个实例化的对象中是公用的。


      数据成员:类变量或者实例变量用于处理类及其实例对象的相关的数据。


      方法重写:如果从父类继承的方法不能满足子类的需求,可以对其进行改写。


      局部变量:定义在方法中的变量,只作用于当前实例的类。


      实例变量:在类的声明中,属性是用变量来表示的,这种变量就称为实例变量。


      类的继承:继承基类的字段和方法。


      类实例化:创建一个类的实例,类的具体对象。


      类的对象:通过类定义的数据结构实例。


1.类的创建

class MyClass:
  x = 123

2.类的实例

class MyClass: 
  x = 123                 # 类属性
myclass = MyClass()       # 实例化
print(myclass.x)          # 调用类属性
# 输出:123
-------------------------------------------------
class MyClass:
  x = 123                
  def y(self):
    return 'hello world'  # 类方法内容
myclass = MyClass()       # 实例化
print(myclass.y())        # 调用类方法 
# 输出:hello world

3.类的调用

class MyClass:
  x = 1.80
  def y(self):
    return '我的身高是{}米。'.format(self.x) # 调用类内部属性
myclass = MyClass()
print(myclass.y())  
# 输出:我的身高是1.8米。

注意:


      1.创建类的方法时,必需要将第一个参数留给 self,并在调用的时候忽略它。


      2.在类的方法中调用类的属性和方法时,要通过self.属性名或 self.方法名()格式调用。


4. __init__

      __init__() 被称为类的构造函数或初始化方法,


      当类实例化操作后会自动调用 __init__() 方法。

class MyClass:
  def __init__(self,x,y):
    self.x = x             
  self.y = y
myclass = MyClass(6,3)
print(myclass.x)
# 输出:6
------------------------------------------
class MyClass:
  def __init__(self,x):
    self.x = x
  print('实例化被打印')
myclass = MyClass(6)        
# 输出:实例化被打印


注意:


      类初始化__init__实例化后会直接被执行打印print()里内容。


5.__str__

      当使用print输出对象的时候,若定义了__str__(self)方法,


      打印对象时就会从这个方法中打印出return的字符串数据。

class MyClass:
  def __init__(self,x):
    self.x = x
  def __str__(self):
  return '我的身高是:{} 米 。'.format(self.x)
myclass = MyClass(1.80)
print(myclass)
# 输出:我的身高是1.8米。
       若将__str__方法注释之后,print输出对象变量,默认情况下,
       输出变量引用对象是哪一个类创建的对象,以及在内存地址。
class MyClass:
  def __init__(self,x):
    self.x = x
myclass = MyClass(1.80)
print(myclass)
# 输出:<__main__.MyClass object at 0x00000000026F90F0>

6.类的继承

class A():
  name = '漫漫'
class B(A):      # 继承类 A 的所有方法和属性
  pass
b = B()
print(b.name)
# 输出:漫漫
-------------------------------------------------------
class A():
  name = '漫漫'
class B():
  name = '桔子'
class C(B,A):  # 优先继承第一个类方法和属性
  pass
c = C()
print(c.name)
# 输出:桔子
-------------------------------------------------------
class A():
  name = '漫漫'
class B():
  name = '桔子'
class C(A,B):    # 优先使用类自身方法和属性
  name = '小漫'
c = C()
print(c.name)
# 输出: 小漫

注意:

      类调取其他类属性名时,如遇两个类内包含相同属性名,优先取第一个参数类内属性值,如类内存已在该属性名,优先调取类内自身属性值。


相关文章
|
1天前
|
开发者 Python
Python入门:8.Python中的函数
### 引言 在编写程序时,函数是一种强大的工具。它们可以将代码逻辑模块化,减少重复代码的编写,并提高程序的可读性和可维护性。无论是初学者还是资深开发者,深入理解函数的使用和设计都是编写高质量代码的基础。本文将从基础概念开始,逐步讲解 Python 中的函数及其高级特性。
Python入门:8.Python中的函数
|
1天前
|
存储 索引 Python
Python入门:6.深入解析Python中的序列
在 Python 中,**序列**是一种有序的数据结构,广泛应用于数据存储、操作和处理。序列的一个显著特点是支持通过**索引**访问数据。常见的序列类型包括字符串(`str`)、列表(`list`)和元组(`tuple`)。这些序列各有特点,既可以存储简单的字符,也可以存储复杂的对象。 为了帮助初学者掌握 Python 中的序列操作,本文将围绕**字符串**、**列表**和**元组**这三种序列类型,详细介绍其定义、常用方法和具体示例。
Python入门:6.深入解析Python中的序列
|
1天前
|
程序员 UED Python
Python入门:3.Python的输入和输出格式化
在 Python 编程中,输入与输出是程序与用户交互的核心部分。而输出格式化更是对程序表达能力的极大增强,可以让结果以清晰、美观且易读的方式呈现给用户。本文将深入探讨 Python 的输入与输出操作,特别是如何使用格式化方法来提升代码质量和可读性。
Python入门:3.Python的输入和输出格式化
|
1天前
|
机器学习/深度学习 人工智能 算法框架/工具
Python入门:1.Python介绍
Python是一种功能强大、易于学习和运行的解释型高级语言。由**Guido van Rossum**于1991年创建,Python以其简洁、易读和十分工程化的设计而带来了庞大的用户群体和丰富的应用场景。这个语言在全球范围内都被认为是**创新和效率的重要工具**。
Python入门:1.Python介绍
|
1天前
|
缓存 算法 数据处理
Python入门:9.递归函数和高阶函数
在 Python 编程中,函数是核心组成部分之一。递归函数和高阶函数是 Python 中两个非常重要的特性。递归函数帮助我们以更直观的方式处理重复性问题,而高阶函数通过函数作为参数或返回值,为代码增添了极大的灵活性和优雅性。无论是实现复杂的算法还是处理数据流,这些工具都在开发者的工具箱中扮演着重要角色。本文将从概念入手,逐步带你掌握递归函数、匿名函数(lambda)以及高阶函数的核心要领和应用技巧。
Python入门:9.递归函数和高阶函数
|
1天前
|
存储 SQL 索引
Python入门:7.Pythond的内置容器
Python 提供了强大的内置容器(container)类型,用于存储和操作数据。容器是 Python 数据结构的核心部分,理解它们对于写出高效、可读的代码至关重要。在这篇博客中,我们将详细介绍 Python 的五种主要内置容器:字符串(str)、列表(list)、元组(tuple)、字典(dict)和集合(set)。
Python入门:7.Pythond的内置容器
|
1天前
|
存储 Linux iOS开发
Python入门:2.注释与变量的全面解析
在学习Python编程的过程中,注释和变量是必须掌握的两个基础概念。注释帮助我们理解代码的意图,而变量则是用于存储和操作数据的核心工具。熟练掌握这两者,不仅能提高代码的可读性和维护性,还能为后续学习复杂编程概念打下坚实的基础。
Python入门:2.注释与变量的全面解析
|
1天前
|
知识图谱 Python
Python入门:4.Python中的运算符
Python是一间强大而且便捷的编程语言,支持多种类型的运算符。在Python中,运算符被分为算术运算符、赋值运算符、复合赋值运算符、比较运算符和逻辑运算符等。本文将从基础到进阶进行分析,并通过一个综合案例展示其实际应用。
|
1月前
|
存储 数据挖掘 数据处理
Python Pandas入门:行与列快速上手与优化技巧
Pandas是Python中强大的数据分析库,广泛应用于数据科学和数据分析领域。本文为初学者介绍Pandas的基本操作,包括安装、创建DataFrame、行与列的操作及优化技巧。通过实例讲解如何选择、添加、删除行与列,并提供链式操作、向量化处理、索引优化等高效使用Pandas的建议,帮助用户在实际工作中更便捷地处理数据。
47 2
|
1月前
|
人工智能 编译器 Python
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈
41 0
python已经安装有其他用途如何用hbuilerx配置环境-附带实例demo-python开发入门之hbuilderx编译器如何配置python环境—hbuilderx配置python环境优雅草央千澈

热门文章

最新文章

推荐镜像

更多