当前位置: 首页 > news >正文

网站运营面试问题专业搜索引擎seo公司

网站运营面试问题,专业搜索引擎seo公司,wdcp设置网站安全,搜索引擎优化是指什么意思这里写自定义目录标题 所用资料 一、从文件中读取数据1.1 读取整个文件1.2 文件路径1.3 逐行读取1.4 创建一个包含文件各行内容的列表1.5 使用文件的内容1.6 包含一百万位的大型文件1.7 圆周率值中包含你的生日吗练习题 二、写入文件2.1 写入空文件2.2 写入多行2.3 附加到文件练…

这里写自定义目录标题

      • 所用资料
  • 一、从文件中读取数据
    • 1.1 读取整个文件
    • 1.2 文件路径
    • 1.3 逐行读取
    • 1.4 创建一个包含文件各行内容的列表
    • 1.5 使用文件的内容
    • 1.6 包含一百万位的大型文件
    • 1.7 圆周率值中包含你的生日吗
    • 练习题
  • 二、写入文件
    • 2.1 写入空文件
    • 2.2 写入多行
    • 2.3 附加到文件
    • 练习题
  • 三、异常
    • 3.1 ZeroDivisionError异常
    • 3.2 使用 try - except 模块
    • 3.3 try - except - else 代码块
    • 3.4 处理 FileNotFoundError 异常
    • 3.5 分析文本的字符
    • 3.6 分析多个文件
    • 3.7 遇到异常时保持静默
    • 练习题
  • 四、存储数据
    • 4.1 使用json.dump( )和json.load( )
    • 4.2 保存和读取用户生成的数据

所用资料

代码中所用到的文件可以从下面的网站进行下载:
https://www.ituring.com.cn/book/2784
在这里插入图片描述

一、从文件中读取数据

1.1 读取整个文件

在这里插入图片描述

with open('files/pi_digits.txt') as file_object:contents = file_object.read()
print(contents)

在这里插入图片描述

  • open函数

打开一个文件。接收参数为需要打开的文件名。Python会在当前执行的文件所在目录下查找指定文件,因此需要把pi_digits.txt文件放在执行文件的同目录下。
open函数返回一个表示文件的对象,Python将通过as关键字该对象赋予file_object。

  • with关键字

再不需要访问文件后,Python会将其自动关闭。比直接使用close函数(关闭文件函数)更加安全。

  • read函数

读取文件内容,以字符串形式赋给contents变量。read函数在读取到文件末尾时会返回一个空字符串,打印出来就是一个空行,可以对contents中使用rstrip函数进行结尾的空行删除。

with open('pi_digits.txt') as file_object:contents = file_object.read()
print(contents.rstrip())

在这里插入图片描述
可以看到空白行被删除掉了。

1.2 文件路径

  • 相对路径: 相对于当前运行的程序所在的目录位置进行查找。如当前运行的程序为python_work,其中有一个名为files的文件夹存储了file.txt文件,路径为: files\file.txt,python会自动在python_work中寻找。

  • 绝对路径:计算机中文件存储的准确位置,如:C:学习\Python从入门到实践第二版源代码文件\源代码文件\chapter_10。因为绝对路径较长,一般会将该字符串先赋给一个变量file_path,然后传入Open函数中

:显示文件路径时,Windows系统使用反斜杠(\ )而不是斜杠(/ ),但在代码中使用斜杠来代表路径。

1.3 逐行读取

以每一行的方式读取文件:使用for循环。

file_path = 'files/pi_digits.txt'
with open(file_path) as file_object:for line in file_object:print(line.rstrip())

使用for循环,让变量line代表文件中的每一行进行输出。

在这里插入图片描述

1.4 创建一个包含文件各行内容的列表

  • readlines函数:从文件中读取每一行并将其存储在一个列表中。
  • readline函数:从文件中读取一行,并作为字符串保存。
file_path = 'files/pi_digits.txt'
with open(file_path) as file_object:line = file_object.readline()lines = file_object.readlines()print(line)
print(lines)

代码使用lines接收readlines函数读到的存储文件中的每一行内容的列表。
可以看到每一行后面都有一个换行符。

在这里插入图片描述
读取到的lines即可使用for循环进行每一行内容的读取。

1.5 使用文件的内容

将文件读取到内存中后即可使用数据。

Python中有三个去除头尾字符、空白符的函数,它们依次为:

  • strip: 用来去除头尾字符、空白符(包括\n、\r、\t、’ ‘,即:换行、回车、制表符、空格)
  • lstrip:用来去除开头字符、空白符(包括\n、\r、\t、’ ‘,即:换行、回车、制表符、空格)
  • rstrip:用来去除结尾字符、空白符(包括\n、\r、\t、’ ',即:换行、回车、制表符、空格)

为了把文件中拿到的内容整合成一行没有中间空白字符的字符串,使用strip函数进行去空白。

去空白函数

file_path = 'files\pi_digits.txt'with open(file_path) as file_objects:lines = file_objects.readlines()pi_strings = ""
for line in lines:pi_strings += line.strip()print(pi_strings)
print(len(pi_strings))
pi_number = float(pi_strings)
print(pi_number)
print(type(pi_number))

strip函数不仅可以删除每行后面的空白字符,还可以把每行开头的空白符也进行删除。这样就得到了一个pi_string的字符串。

如果想后续进行数值的计算,需要把字符串转为数值进行使用,可以使用float函数进行类型转换。

在这里插入图片描述

1.6 包含一百万位的大型文件

所需文件:

在这里插入图片描述

读取一个精确到小数点后1000000位的圆周率文件。

file_path = 'files/pi_million_digits.txt'with open(file_path) as file_objects:lines = file_objects.readlines()pi_string = ""
for line in lines:pi_string += line.strip()print(pi_string[:52])
print(len(pi_string))

打印前52位,然后输出一下字符串的长度,证明确实是有1000002位数。

在这里插入图片描述

1.7 圆周率值中包含你的生日吗

可以查看一下自己的生日是否在圆周率中,如果存在,使用index函数查找到生日字符串在pi字符串中的位置并且输出。

file_path = 'files/pi_million_digits.txt'with open(file_path) as file_objects:lines = file_objects.readlines()pi_string = ""
for line in lines:pi_string += line.strip()birthday = input("Please enter your birthday, in the form mmdd: ")if birthday in pi_string:print(f"Your birthday appears in the first million digits of pi at the index of {pi_string.index(birthday)}!")
else:print("Sorry~")

练习题

在这里插入图片描述
在这里插入图片描述

file_path = 'files/learning_python.txt'with open(file_path) as file_objects:contents = file_objects.read()
print(contents)with open(file_path) as file_objects:for line in file_objects:print(line.rstrip())with open(file_path) as file_objects:lines = file_objects.readlines()
print(lines)

在这里插入图片描述

file_path = 'files/learning_python.txt'with open(file_path) as f:lines = f.readlines()for line in lines:print(line.rstrip().replace('Python','c++'))

在这里插入图片描述

二、写入文件

2.1 写入空文件

调用open() 时提供了两个实参:

  • 第一个实参:要打开的文件的名称。
  • 第二个实参(‘w’ ):告诉Python要以写入模式打开这个文件。

打开文件时,可指定读取模式 (‘r’ )、写入模式 (‘w’ )、附加模式 (‘a’ )或读写模式 (‘r+’ )。如果省略了模式实参,Python将以默认的只读模式打开文件。

如果要写入的文件不存在,函数open() 将自动创建它

然而,以写入模式(‘w’)打开文件时千万要小心,因为如果指定的文件已经存在,Python将在返回文件对象前清空该文件的内容。

Python只能将字符串写入文本文件。 要将数值数据存储到文本文件中,必须先使用函数str() 将其转换为字符串格式。

filename = 'programming.txt'with open(filename,'w') as f:f.write('I love programming!')

在这里插入图片描述

2.2 写入多行

在writer函数中添加换行符。

filename = 'programming.txt'with open(filename,'w') as f:f.write('I love writing!\n')f.write('I love programming!\n')

在这里插入图片描述

2.3 附加到文件

如果不想覆盖掉之前的内容,而是想给文件添加内容的话,可以以附加模式(a) 打开文件。

以附加模式打开文件时,Python不会在返回文件对象前清空文件的内容,而是将写入文件的行添加到文件末尾。

如果指定的文件不存在,Python将为你创建一个空文件。

filename = 'programming.txt'with open(filename,'a') as f:f.write('I love painting!\n')f.write('I love swimming!\n')with open(filename) as f:lines = f.read()
print(lines)

在这里插入图片描述

练习题

在这里插入图片描述

10-3

filename = 'guests.txt'
name = input('enter the name: ')
with open(filename,'w') as f:f.write(name.title())

10-4

filename = 'guest_book.txt'
with open (filename,'a') as f:while True:name = input("Enter the name: ")if name == 'q':breakprint(f"Hi, {name.title()} !")f.write(f"{name.title()}\n")

在这里插入图片描述
在这里插入图片描述
10-5

filename = 'reason.txt'
with open(filename,'a') as f:while True:reason = input('Enter the reason why you like programming')if reason=='quit':breakf.write(f"{reason}\n")

三、异常

异常:一个特殊对象,管理程序执行期间发生的错误。
每当发生让Python不知所措的错误时,它都会创建一个异常对象。如果你编写了处理该异常的代码,程序将继续运行;如果未对异常进行处理,程序将停止并显示traceback,其中包含有关异常的报告。

异常是使用try-except 代码块处理的。
try-except 代码块让Python执行指定的操作,同时告诉Python发生异常时怎么办。使用try-except 代码块时,即便出现异常,程序也将继续运行:显示你编写的友好的错误消息,而不是令用户迷惑的traceback。

3.1 ZeroDivisionError异常

ZeroDivisionError异常:被除数不能为0的异常。

在这里插入图片描述

3.2 使用 try - except 模块

当认为可能会发生错误时,可编写一个try-except 代码块来处理可能引发的异常。

  • try下写让Python尝试运行一些代码,
  • except下写如果这些代码引发了指定的异常该怎么办。
try:print(5/0)
except ZeroDivisionError:print("You can't divide by zero! ")

将导致错误的代码行 print(5/0) 放在一个try 代码块中。如果try 代码块中的代码运行起来没有问题,Python将跳过except 代码块;如果try 代码块中的代码导致了错误,Python将查找与之匹配的except 代码块并运行其中的代码。

在本例中,try 代码块中的代码引发了ZeroDivisionError 异常,因此Python查找指出了该怎么办的except 代码块,并运行其中的代码。这样,用户看到的是一条友好的错误消息,而不是traceback。

3.3 try - except - else 代码块

使用try-except进行异常处理,而依赖try代码块成功执行的代码都应放到else代码块中。

while True:n1 = input("First number: ")if n1 == 'q':breakn2 = input('Second number: ')if n2 == 'q':breaktry:result = int(n1)/int(n2)except ZeroDivisionError:print("You can't divide by 0!")else:print(result)

在这里插入图片描述

3.4 处理 FileNotFoundError 异常

FileNotFoundError 异常:找不到文件
在这里插入图片描述

filename = 'alice.txt'try:with open(filename) as f:contents = f.read()except FileNotFoundError:print(f"{filename} doesn't exit!")

在这里插入图片描述

3.5 分析文本的字符

统计alice.txt文件中所有的英文单词数量。
在这里插入图片描述

  • split()函数:为一个字符串中的英文单词创建一个单词列表
  • encoding = ‘utf-8’:当系统默认编码和读取文件使用的编码不一致时使用。
filename = 'alice.txt'try:with open(filename,encoding = 'utf-8') as f:contents = f.read()except FileNotFoundError:print(f"{filename} doesn't exit!")else:words = contents.split()num_word = len(words)print(f"The file {filename} has about {num_word} words.")

在这里插入图片描述

3.6 分析多个文件

filenames = [‘alice.txt’,‘siddhartha.txt’,‘mobd_dick.txt’]

其中siddhartha.txt文件不存在。使用for循环对文件列表中的文件一次读取并且分析。

def count_words(filename):try:with open(filename, encoding='utf-8') as f:contents = f.read()except FileNotFoundError:print(f"{filename} doesn't exit!")else:words = contents.split()num_word = len(words)print(f"The file {filename} has about {num_word} words.")filenames = ['alice.txt','siddhartha.txt','moby_dick.txt']
for filename in filenames:count_words(filename)

在这里插入图片描述

3.7 遇到异常时保持静默

如果想要发生异常时程序什么也不说,像什么都没有发生过一样继续执行,那就在except模块下使用pass语句

def count_words(filename):try:with open(filename, encoding='utf-8') as f:contents = f.read()except FileNotFoundError:passelse:words = contents.split()num_word = len(words)print(f"The file {filename} has about {num_word} words.")filenames = ['alice.txt','siddhartha.txt','moby_dick.txt']
for filename in filenames:count_words(filename)

在这里插入图片描述

练习题

在这里插入图片描述
在这里插入图片描述

10-6

try:n1 = int(input("the first number is :"))n2 = int(input("The second number is :"))
except ValueError:print("Please enter number not text!")
else:print(n1+n2)

10-7

while True:try:n1 = int(input("the first number is :"))n2 = int(input("The second number is :"))except ValueError:print("Please enter number not text!")else:print(n1+n2)

10-8

四、存储数据

JSON格式:存储数据结构,最初是为JavaScript开发,但随后成了一种常见格式,被包括Python在内的众多语言采用。

模块json 让你能够将简单的Python数据结构转储到文件中,并在程序再次运行时加载该文件中的数据。

还可以使用json 在Python程序之间分享数据。

更重要的是,JSON数据格式并非Python专用的,JSON格式存储的数据可以与使用其他编程语言共享。

4.1 使用json.dump( )和json.load( )

  • 函数json.dump() : 把数据存储在文件中。接受两个实参,要存储的数据,以及可用于存储数据的文件对象。

  • json.load() : 把数据读取到内存中。

import json
numbers = [2,3,4,5,7.11,13]
filename = 'numbers.json'
with open(filename,'w') as f:json.dump(numbers,f)

首先import json模块,然后使用json.dump把数字列表存储进number.json文件中。

在这里插入图片描述

使用json.load(f)把numbers.json文件中的数据结构存进内存中,然后打印输出。

import json
filename = 'numbers.json'
with open(filename) as f:numbers = json.load(f)
print(numbers)

在这里插入图片描述

4.2 保存和读取用户生成的数据

http://www.yidumall.com/news/105554.html

相关文章:

  • 库尔勒 网站建设长沙建设网站制作
  • 做棋牌网站违法吗厦门seo网络推广
  • 做网站很累网站建设公司网站
  • 温岭建设规划局网站友情链接互换网站
  • python做网站用什么框架石家庄疫情最新消息
  • 江苏初中课程基地建设网站软文小故事200字
  • 微软做网站一站式自媒体服务平台
  • 哪个公司做公司网站好重庆seo研究中心
  • 河南省网站制作公司seo排名优化工具推荐
  • 聊城网站推广品牌全网关键词云查询
  • 网站做任务佣金东莞网络优化哪家好
  • 网站与云平台区别网站关键词优化多少钱
  • 网站网站制作网站天津seo排名效果好
  • 哈尔滨做网站公司有哪些中国重大新闻
  • 上海网站建设天锐科技昆明长尾词seo怎么优化
  • 网站网页的书签怎么做武汉企业seo推广
  • 免费网站建设itcask自媒体
  • 公司网站建设计入明细科目网络推广的渠道
  • 用帝国cms做门户网站windows优化大师是哪个公司的
  • 泰塔科技网站建设苏州seo网站系统
  • 常州制作网站抖音seo培训
  • 自己搭建的ftp怎么做网站广州广告公司
  • 自己做微信电影网站怎么做对百度竞价排名的看法
  • 做同城相亲网站知识搜索引擎
  • 怎么做类似淘宝的网站百度网页版链接地址
  • 淮北网站建设求职简历seo优化中商品权重主要由什么决定
  • 网站优化新闻湛江今日头条
  • 手工制作风筝外链seo招聘
  • 专业的建网站的公司网站搜索排名优化怎么做
  • 搭建电商平台 方案重庆高端seo