欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

抽獎函數(shù)python讀寫,用python寫抽獎程序

python常用函數(shù)包有哪些?

一些python常用函數(shù)包:

成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供象山網(wǎng)站建設(shè)、象山做網(wǎng)站、象山網(wǎng)站設(shè)計、象山網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、象山企業(yè)網(wǎng)站模板建站服務(wù),10余年象山做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。

1、Urllib3

Urllib3是一個 Python 的 HTTP 客戶端,它擁有 Python 標準庫中缺少的許多功能:

線程安全

連接池

客戶端 SSL/TLS 驗證

使用分段編碼上傳文件

用來重試請求和處理 HTTP 重定向的助手

支持 gzip 和 deflate 編碼

HTTP 和 SOCKS 的代理支持

2、Six

six 是一個是 Python 2 和 3 的兼容性庫。這個項目旨在支持可同時運行在 Python 2 和 3 上的代碼庫。它提供了許多可簡化 Python 2 和 3 之間語法差異的函數(shù)。

3、botocore、boto3、s3transfer、awscli

Botocore是 AWS 的底層接口。Botocore是 Boto3 庫(#22)的基礎(chǔ),后者讓你可以使用 Amazon S3 和 Amazon EC2 一類的服務(wù)。Botocore 還是 AWS-CLI 的基礎(chǔ),后者為 AWS 提供統(tǒng)一的命令行界面。

S3transfer(#7)是用于管理 Amazon S3 傳輸?shù)?Python 庫。它正在積極開發(fā)中,其介紹頁面不推薦人們現(xiàn)在使用,或者至少等版本固定下來再用,因為其 API 可能發(fā)生變化,在次要版本之間都可能更改。Boto3、AWS-CLI和其他許多項目都依賴s3transfer。

4、Pip

pip是“Pip Installs Packages”的首字母遞歸縮寫。

pip很容易使用。要安裝一個包只需pip install package name即可,而刪除包只需pip uninstall package name即可。

最大優(yōu)點之一是它可以獲取包列表,通常以requirements.txt文件的形式獲取。該文件能選擇包含所需版本的詳細規(guī)范。大多數(shù) Python 項目都包含這樣的文件。

如果結(jié)合使用pip與virtualenv(列表中的 #57),就可以創(chuàng)建可預(yù)測的隔離環(huán)境,同時不會干擾底層系統(tǒng),反之亦然。

5、Python-dateutil

python-dateutil模塊提供了對標準datetime模塊的強大擴展。我的經(jīng)驗是,常規(guī)的Python datetime缺少哪些功能,python-dateutil就能補足那一塊。

6、Requests

Requests建立在我們的 #1 庫——urllib3基礎(chǔ)上。它讓 Web 請求變得非常簡單。相比urllib3來說,很多人更喜歡這個包。而且使用它的最終用戶可能也比urllib3更多。后者更偏底層,并且考慮到它對內(nèi)部的控制級別,它一般是作為其他項目的依賴項。

7、Certifi

近年來,幾乎所有網(wǎng)站都轉(zhuǎn)向 SSL,你可以通過地址欄中的小鎖符號來識別它。加了小鎖意味著與該站點的通信是安全和加密的,能防止竊聽行為。

8、Idna

根據(jù)其 PyPI 頁面,idna提供了“對 RFC5891 中指定的應(yīng)用程序中國際化域名(IDNA)協(xié)議的支持。”

IDNA的核心是兩個函數(shù):ToASCII和ToUnicode。ToASCII會將國際 Unicode 域轉(zhuǎn)換為 ASCII 字符串。ToUnicode則逆轉(zhuǎn)該過程。在IDNA包中,這些函數(shù)稱為idna.encode()和idna.decode()

9、PyYAML

YAML是一種數(shù)據(jù)序列化格式。它的設(shè)計宗旨是讓人類和計算機都能很容易地閱讀代碼——人類很容易讀寫它的內(nèi)容,計算機也可以解析它。

PyYAML是 Python 的YAML解析器和發(fā)射器,這意味著它可以讀寫YAML。它會把任何 Python 對象寫成YAML:列表、字典,甚至是類實例都包括在內(nèi)。

10、Pyasn1

像上面的IDNA一樣,這個項目也非常有用:

ASN.1 類型和 DER/BER/CER 編碼(X.208)的純 Python 實現(xiàn)

所幸這個已有數(shù)十年歷史的標準有很多信息可用。ASN.1是 Abstract Syntax Notation One 的縮寫,它就像是數(shù)據(jù)序列化的教父。它來自電信行業(yè)。也許你知道協(xié)議緩沖區(qū)或 Apache Thrift?這就是它們的 1984 年版本。

11、Docutils

Docutils是一個模塊化系統(tǒng),用來將純文本文檔處理為很多有用的格式,例如 HTML、XML 和 LaTeX 等。Docutils能讀取reStructuredText格式的純文本文檔,這種格式是類似于 MarkDown 的易讀標記語法。

12、Chardet

你可以用chardet模塊來檢測文件或數(shù)據(jù)流的字符集。比如說,需要分析大量隨機文本時,這會很有用。但你也可以在處理遠程下載的數(shù)據(jù),但不知道用的是什么字符集時使用它。

13、RSA

rsa包是一個純 Python 的 RSA 實現(xiàn)。它支持:

加密和解密

簽名和驗證簽名

根據(jù) PKCS#1 1.5 版生成密鑰

它既可以用作 Python 庫,也能在命令行中使用。

14、Jmespath

JMESPath,發(fā)音為“James path”,使 Python 中的 JSON 更容易使用。它允許你聲明性地指定如何從 JSON 文檔中提取元素。

15、Setuptools

它是用于創(chuàng)建 Python 包的工具。不過,其文檔很糟糕。它沒有清晰描述它的用途,并且文檔中包含無效鏈接。最好的信息源是這個站點,特別是這個創(chuàng)建 Python 包的指南。

16、Pytz

像dateutils一樣,這個庫可幫助你處理日期和時間。有時候,時區(qū)處理起來可能很麻煩。幸好有這樣的包,可以讓事情變得簡單些。

17、Futures

從 Python 3.2 開始,python 提供current.futures模塊,可幫助你實現(xiàn)異步執(zhí)行。futures 包是該庫適用于 Python 2 的 backport。它不適用于 Python3 用戶,因為 Python 3 原生提供了該模塊。

18、Colorama

使用 Colorama,你可以為終端添加一些顏色:

更多Python知識請關(guān)注Python自學網(wǎng)

使用python制作一個抽獎小游戲——骰子游戲

**2. **創(chuàng)建Die類****

5.匯總

這個可以創(chuàng)建多種玩法,隨機搖骰子只是其中的一種,還可以先讓一個人輸入一個幸運數(shù)字并儲存起來,然后再執(zhí)行程序,如果數(shù)字不等于幸運數(shù)字就不是幸運星,當數(shù)字等于時就是幸運星并結(jié)束程序——類似抽獎。。。。

總之玩法很多,看你怎么寫,用最基礎(chǔ)的知識來實現(xiàn)!

怎么用python寫一個抽獎程序,是抽取圖片或視頻

16年年會抽獎網(wǎng)上有人對公司的抽獎結(jié)果又偏見,于是全員進行了抽獎代碼的review,好像是愛奇藝公司的,下面用python來實現(xiàn)一個抽獎程序。

主要功能有

1.從一個csv文件中讀入所有員工工號

2.將這些工號初始到一個列表中

3.用random模塊下的choice函數(shù)來隨機選擇列表中的一個工號

4.抽到的獎項的工號要從列表中進行刪除,以免再次抽到

初級版

這個比較簡單,缺少定制性,如沒法設(shè)置一等獎有幾名,二等獎有幾名

import csv#創(chuàng)建一個員工列表emplist = []#用with自動關(guān)閉文件with open('c://emps.csv') as f:

empf = csv.reader(f) for emp in empf:

emplist.append(emp)

print("進行一等獎抽獎,共有一名")import random#利用random模塊的chice函數(shù)來從列表中隨機選取一個元素e1 = random.choice(emplist)#將中獎的員工從列表中剔除emplist.remove(e1)

print('一等獎得主的號碼是 %s' % e1)

print('進行三個二等獎的號碼抽獎')

e2_1 = random.choice(emplist)

emplist.remove(e2_1)

e2_2 = random.choice(emplist)

emplist.remove(e2_2)

e2_3 = random.choice(emplist)

emplist.remove(e2_3)

print('獲得3個二等獎是 %s %s %s',(e2_1,e2_2,e2_3))#下面依次類推可以設(shè)置三等獎的抽獎123456789101112131415161718192021222324

改進版

上面的那個初級版,假如要設(shè)置個三等獎一百名那么將要重新維護幾百行代碼,下面用比較高級點的辦法實現(xiàn).

我們考慮用面向?qū)ο髞韺崿F(xiàn),設(shè)計一個抽獎類,類中包含一個屬性(號碼來源),一個方法:產(chǎn)生所有抽獎層次指定個數(shù)的抽獎號碼。

用到如下知識點:

1. csv模塊部分函數(shù)用法

2. sys模塊讀取輸入

3. random模塊函數(shù)choice函數(shù)用法

4. 列表和字典元素的添加、刪除

6. for循環(huán)中range用法

7. 類和面向?qū)ο?/p>

8. 字符打印,print中的計算

9.open中with

#!/usr/bin/python#coding=utf-8import csvimport sysimport random

reload(sys)

sys.setdefaultencoding('utf8')#coding=utf-8print("開始進行抽獎")#定義個抽獎類,功能有輸入抽獎級別和個數(shù),打印出每個級別的抽獎員工號碼class Choujiang:

#定義scv文件路徑

def __init__(self,filepath):

self.empfile = filepath def creat_num(self):

emplist = [] with open(self.empfile) as f:

empf = csv.reader(f) for emp in empf:

emplist.append(emp)

print('共有%s 人參與抽獎' % len(emplist))

levels = int(input('抽獎分幾個層次,請輸入:')) #定義一個字典

level_dict = {} for i in range(0,levels):

print('請輸入當前獲獎層次 %s 對應(yīng)的獎品個數(shù)' % ( i + 1))

str_level_dict_key = sys.stdin.readline()

int_level_dict_key = int(str_level_dict_key)

level_dict[i] = int_level_dict_key #循環(huán)完成后抽獎層次字典構(gòu)造完畢

#進行抽獎開始

print('抽獎字典設(shè)置為: %s' % level_dict) for i in range(0,len(level_dict)):

winers = [] #產(chǎn)生當前抽獎層次i對應(yīng)的抽獎個數(shù)

for j in range(0,int(level_dict[i])): #利用random模塊中的choice函數(shù)從列表中隨機產(chǎn)生一個

winer = random.choice(emplist)

winers.append(winer)

emplist.remove(winer)

print('抽獎層次 %s 下產(chǎn)出的獲獎人員有:' % (i + 1 ))

print(winers)#類功能定義完畢,開始初始化并使用if __name__ == '__main__':

peoples = Choujiang('c://emps.csv')

peoples.creat_num()1234567891011121314151617181920212223242526272829303132333435363738394041424344454647

該段程序在python 2.6 以上及 3中均可以運行,運行結(jié)果如下圖:

Python 3.4.3 (v3.4.3:9b73f1c3e601, Feb 24 2015, 22:44:40) [MSC v.1600 64 bit (AMD64)] on win32

Type "copyright", "credits" or "license()" for more information. ================================ RESTART ================================ 開始進行抽獎

共有24790 人參與抽獎

抽獎分幾個層次,請輸入:2請輸入當前獲獎層次 1 對應(yīng)的獎品個數(shù)1請輸入當前獲獎層次 2 對應(yīng)的獎品個數(shù)3抽獎字典設(shè)置為: {0: 1, 1: 3}

抽獎層次 1 下產(chǎn)出的獲獎人員有:

[['張三19826']]

抽獎層次 2 下產(chǎn)出的獲獎人員有:

[['張三18670'], ['張三23235'], ['張三15705']] 1234567891011121314151617

python編寫抽獎程序?

#data和name_data數(shù)據(jù)自己添加

import random

# 所有員工數(shù)據(jù),字典的key是一個set類型,value是list類型

data = {

('能永年', '甲隊'): ['項目隊長', '曾經(jīng)外派抵達x地做出了某事', '曾經(jīng)外派抵達子公司做出了ss項目'],

('巴偉毅', '乙隊'): ['HR'],

('紀文博', '丙隊'): ['項目成員', '為xx事做出了重大貢獻', '曾經(jīng)做過AA項目'],

('吉信鴻', '丙隊'): ['HR', '為公司面試了XX人次', ],

('沙雅旭', '丙隊'): ['財務(wù)管理', '針對財務(wù)的做出了重要指導'],

}

name_data = ['能永年', '巴偉毅', '紀文博', '吉信鴻', '沙雅旭'] ?# 參見抽獎人的姓名

random_name = random.choice(name_data) ?# 隨機一個中獎的人

for key, value in data.items():

# print(key,value)

if random_name == key[0]: ?# 在字典key中找到這人

print('{}:{}'.format(key[0], key[1]))

for item in value: ?# 遍歷他的信息

print('\t\t' + item.ljust(20))

python對文本文件的讀有哪些方法,寫有哪些方法?

1 文件讀取全文本操作

在一定場景下我們需要把文本全部內(nèi)容讀取出來,進行處理。python提供三種函數(shù)讀取文件,分別是read readline readlines,

read():讀取文件的全部內(nèi)容,加上參數(shù)可以指定讀取的字符。

readline():讀取文件的一行。

readlines():讀取文件的所有行到內(nèi)存中。

不同場景下我們可以選擇不同函數(shù)對文件進行讀取。

1.1 方法一

file_name = input("請輸入你要打開的文件的完整路徑及名稱")

file= open(file_name, "r")

txt=file.read()

# 全文本的處理

file.close()

使用read函數(shù)將文件中的內(nèi)容全部讀取,放在字符串變量txt中。這樣操作適合于文本較小,處理簡單的情況,當文件較大時,這種方式處理時不合適的。一次性讀取較大的文件到內(nèi)存中,會耗費較多的時間和資源。這時候分批處理效果更好。

1.2 方法二

file_name = input("請輸入你要打開的文件的完整路徑及名稱")

file= open(file_name, "r")

txt= file.read(4)

# 文本的處理while txt != ""txt= file.read(4)

# 批量文本處理

file.close()

這種方法適合于分批處理文本信息,每次批量讀入,批量處理,不會對內(nèi)存造成較大的壓力。

1.3 方法三

file_name = input("請輸入你要打開的文件的完整路徑及名稱")

file= open(file_name, "r")for line infile.readlines():

# 處理每一行數(shù)據(jù)

file.close()

這種處理方式適合處理以行為分割特點的文本,并且文本較小,因為這種處理方式需要一次性把文件所有內(nèi)容讀取到內(nèi)存中。

1.4 方法四

file_name = input("請輸入你要打開的文件的完整路徑及名稱")

file= open(file_name, "r") # 這里的file時文件句柄for line infile:

# 處理每一行數(shù)據(jù)

file.close()

這種方式和方法三中的區(qū)別是分行讀入,逐行處理,不會一次性把文件所有內(nèi)容都讀入到內(nèi)存中,對一些大文件的處理是很有效的。

2 文件寫入文本操作

文件寫入有兩種寫入函數(shù)和一種輔助支持。

write():向文件中寫入一個字符或者字節(jié)流

writelines():將一個元素全為字符串的列表寫入到文件中 需要注意的是,writelines寫入列表元素的時候會把列表元素的內(nèi)容拼接到一起寫入,不會有換行和空格 。

seek(): 輔助寫入函數(shù)offset偏移量參數(shù)代表含義如下

0 - 文件開頭

1 - 當前位置

2 - 文件結(jié)尾

2.1 方法一

file_name = input("output.txt", "w+")

text= "hello world!"file_name.write(text)

file.close()

2.2 方法二

file_name = input("output.txt", "w+")

list= ["中午","早上","晚上"]

file_name.writelines(list)for line infile:

# 讀取寫入的數(shù)據(jù),這時候發(fā)現(xiàn)是沒有任何內(nèi)容的

file.close()

我們增加一行代碼就可以讀取到寫入的文件內(nèi)容,利用seek()函數(shù)調(diào)整寫操作指針的位置,可以實現(xiàn)寫操作之后的正常讀取。

file_name = input("output.txt", "w+")

list= ["中午","早上","晚上"]

file_name.readlines(list)

file_name.seek(0) # 調(diào)整寫的指針到文件的開始位置for line infile:

# 讀取寫入的數(shù)據(jù),這時候會讀出一行寫入的數(shù)據(jù)。

file.close()

Python其實很簡單 第十五章 文件操作

在各種變量中保存的數(shù)據(jù)都是臨時的,隨著程序運行結(jié)束都會丟失。要做到數(shù)據(jù)長期有效,必須建立在磁盤中建立文件,將數(shù)據(jù)輸入到文件中并保存。需要獲取數(shù)據(jù)時需要打開文件讀取。

而我們自己建立的程序都是應(yīng)用程序,從本質(zhì)上講,應(yīng)用程序是無法直接操作計算機的硬件的,譬如讀寫磁盤中文件,這就需要調(diào)用操作系統(tǒng)中的相應(yīng)命令。接下來我們使用的Python內(nèi)置函數(shù)open()、write()都是通過調(diào)用操作系統(tǒng)的相關(guān)命令才實現(xiàn)文件讀寫的,至于其中的細節(jié),我們就不需要考慮了。

15.1創(chuàng)建和打開文件

在Python 中創(chuàng)建或打開文件,實際上是建立一個對象,該對象通過調(diào)用內(nèi)置的open()函數(shù)創(chuàng)建或打開一個文件。

語法:

file object = open(filename [, mode][, buffering])

參數(shù)說明如下:

filename:file_name變量是一個包含了你要訪問的文件名稱的字符串值;

mode:mode決定了打開文件的模式:只讀,寫入,追加等。所有可取值見如下的完全列表。這個參數(shù)是非強制的,默認文件訪問模式為只讀(r)。

Buffering:如果buffering的值被設(shè)為0,就不會有寄存;如果buffering的值取1,訪問文件時會寄存行;如果將buffering的值設(shè)為大于1的整數(shù),表明了這就是的寄存區(qū)的緩沖大小;如果取負值,寄存區(qū)的緩沖大小則為系統(tǒng)默認。

mode參數(shù)的參數(shù)值及說明

對于其中最難區(qū)別的r、r+、w、w+、a、a+幾個參數(shù)的區(qū)別總結(jié)如下,要特別注意指針的位置:

下面舉例說明open( )函數(shù)的使用方法。

例1:

file=open('1.py')

如果文件“1.py”存在,則可以打開此文件;如果文件“1.py”不存在,則會出現(xiàn)如下提示:

Traceback (most recent call last):

File " ", line 1, in

file=open('1.py')

FileNotFoundError: [Errno 2] No such file or directory: '1.py'

例2:

file=open('4.py',’a+’)

雖然文件“4.py”不存在,但運行并未出現(xiàn)錯誤,參見上表,“a+”的含義是以讀寫模式打開文件,如果該文件已經(jīng)存在,新內(nèi)容將以追加方式寫入;如果該文件不存在,則新建文件用于寫入。查看文件夾,發(fā)現(xiàn)已經(jīng)生成了一個新的文件4.py。

例3:

file=open('python.png','rb')

print(file)

運行結(jié)果:

這就是說,雖然Python可以打開一個圖片格式的文件,但print()并不能將其輸出,還需要第三方庫中模塊的相應(yīng)方法去處理,如PIL中的open()f方法。

例4:

file = open("f.txt", "w",encoding='utf-8')

# 以只寫模式打開文件f.txt,編碼方式為utf-8

print( "文件名: ", file.name) # 輸出文件名

print( "是否已關(guān)閉 : ", file.closed) # 文件是否打開

print( "訪問模式 : ", file.mode) # 文件訪問模式

運行結(jié)果:

文件名: f.txt

是否已關(guān)閉 : False

訪問模式 : w

例5:

15.2關(guān)閉文件

打開文件使用后要及時關(guān)閉,以免造成不必要的破壞,同時也可以釋放內(nèi)存。在Python中使用close()方法可以關(guān)閉文件。

語法格式:

file.close()

其中,file為文件對象。

15.3 with語句

with 語句適用于對資源進行訪問的場合,確保不管使用過程中是否發(fā)生異常都會執(zhí)行必要的“清理”操作,釋放資源,比如文件使用后自動關(guān)閉、線程中鎖的自動獲取和釋放等。

with語句的語法格式如下:

with expression as target:

with-body

其中,expression用于指定一個表達式,譬如打開文件的open()函數(shù)。target用于指定一個變量,并且將expression的結(jié)果保存到該變量中,譬如文件對象file。with-body用于指定with語句體,譬如一些文件操作的相關(guān)語句,如果沒有要執(zhí)行的語句體,則直接用pass語句代替。

假設(shè)python當前目錄下存在一個test.txt文件,其內(nèi)容如下:

Python是一種解釋型語言: 這意味著開發(fā)過程中沒有了編譯這個環(huán)節(jié)。類似于PHP和Perl語言。

Python是交互式語言: 這意味著,您可以在一個 Python 提示符 后直接執(zhí)行代碼。

Python是面向?qū)ο笳Z言: 這意味著Python支持面向?qū)ο蟮娘L格或代碼封裝在對象的編程技術(shù)。

Python是初學者的語言:Python 對初級程序員而言,是一種偉大的語言,它支持廣泛的應(yīng)用程序開發(fā)。

舉例如下:

with open('test.txt','r',encoding='utf-8') as file:

line=file.readline() # readline()方法可以讀取文件一行數(shù)據(jù),接下來就會講到。

print(line)

運行結(jié)果如下:

Python是一種解釋型語言: 這意味著開發(fā)過程中沒有了編譯這個環(huán)節(jié)。類似于PHP和Perl語言。

而此時,我們給該段代碼with語句之外再增加一個讀取文件的語句,代碼如下:

with open('test.txt','r',encoding='utf-8') as file:

line=file.readline()

print(line)

line2=file.readline()

print(line2)

發(fā)現(xiàn)出現(xiàn)了如下錯誤提示:

Traceback (most recent call last):

File "C:/Users/zym/AppData/Local/Programs/Python/Python39/3.py", line 5, in

line2=file.readline()

ValueError: I/O operation on closed file.

意思是要讀取的文件已經(jīng)被關(guān)閉了。

由此可知,當with語句運行結(jié)束后,被打開的test.txt文件就自動關(guān)閉了。

15.4讀取文件

在Python 中讀取文件的方法有:

1、讀取指定個數(shù)的字符

格式如下:

File.read([size])

其中,file為打開的文件對象。size為可選參數(shù),可以指定要讀取的字符個數(shù),省缺表示讀取所有內(nèi)容。

在調(diào)用read()方法讀取文件內(nèi)容時,文件必須是以r(只讀)或者r+(讀寫)方式打開。

如:

with open('test.txt','r',encoding='utf-8') as file:

txt=file.read() (或txt=file.read(10))

print(txt)

將讀取、輸出test.txt文件的全部內(nèi)容(或前10個字符)。

2、移動文件的指針

對于剛打開的文件,文件指針總是指向文件頭的。也可以通過seek()方法將文件的指針移動到新的位置。

格式如下:

file.seek(offset[,whence])

其中,file表示已經(jīng)打開的文件對象;offset用于指定移動的字符個數(shù);whence表示從哪個位置起始計算個數(shù),其值為0表示從文件頭開始計算,其值為1表示從當前位置開始計算,其值為2表示從文件尾開始計算,默認值為0。

例如:

with open('test.txt','r',encoding='utf-8') as file:

string=file.read(9)

print('取9個字符: '+string)

file.seek(2) #指針從文件頭開始移動2個字符

string=file.read(9) #從當前位置讀取10個字符

輸出結(jié)果:

取9個字符:

Python是一種

取9個字符:

thon是一種解釋

而下面的代碼會拋出錯誤:

with open('test.txt','r',encoding='utf-8') as file:

file.seek(2,1) #指針從當前位置開始移動2個字符

string=file.read(10) #從當前位置讀取10個字符

print('取10個字符: '+string)

錯誤提示為:

Traceback (most recent call last):

File "C:UserszymAppDataLocalProgramsPythonPython393.py", line 7, in

file.seek(2,1) #指針從當前位置開始移動2個字符

io.UnsupportedOperation: can't do nonzero cur-relative seeks

原因在于,必須使用b模式(即rb)打開文件,才能使用whence參數(shù)。但是,b模式(二進制)不適合文本文件。對于test.txt這樣的文本文件,為了解決通過改變指針讀取任意位置字符,可以采用加一個位置變量的方法來存儲指針的值。

例如:

with open('test.txt','r',encoding='utf-8') as file:

#utf-8漢字與英文字符都占一個字符

string='' #設(shè)置一個空字符串

pointer=0 #當前指針為0

str1=file.read(6) #讀取6個字符

pointer+=6 #指針變量后移6個字符

string+=str1 #string用來存放已讀取的字符

print('取6個字符: ',str1)

file.seek(pointer) #指針從文件頭開始移動2個字符

str1=file.read(8) #從當前位置讀取10個字符

pointer+=8 #指針跳過已讀取的字符

string+=str1

print('再取8個字符: ',str1)

print('所有讀取的字符: ',string)

print('當前指針所處的位置: ',pointer)

str1=file.read(1)

print('當前指針所處的字符: ',str1)

運行結(jié)果如下:

取6個字符:

Python

再取8個字符:

是一種解釋型語言

所有讀取的字符:

Python是一種解釋型語言

當前指針所處的位置:

14

當前指針所處的字符:

3、讀取一行數(shù)據(jù)readline()方法

語法格式:

file.readline()

例:

with open('test.txt','r',encoding='utf-8') as f:

string=f.read(1) # 讀取文件的第一個字符

if string != '': # 防止文件為空文件

lineno=0

while True:

line=f.readline()

if line != '':

lineno+=1

print('第'+str(lineno)+'行:'+line,end='')

# 因為每行都有自帶的分行符,print()語句不允許換行

else:

break # 出現(xiàn)空行時停止讀取

else:

print('要讀取的文件為空文件!')

運行結(jié)果:

第1行:ython是一種解釋型語言: 這意味著開發(fā)過程中沒有了編譯這個環(huán)節(jié)。類似于PHP和Perl語言。

第2行:Python是交互式語言: 這意味著,您可以在一個 Python 提示符 后直接執(zhí)行代碼。

第3行:Python是面向?qū)ο笳Z言: 這意味著Python支持面向?qū)ο蟮娘L格或代碼封裝在對象的編程技術(shù)。

第4行:Python是初學者的語言:Python 對初級程序員而言,是一種偉大的語言,它支持廣泛的應(yīng)用程序開發(fā)。

4、讀取全部行命令readlines()方法

語法格式:

File.readlines()

該方法與read()方法一樣,在調(diào)用read()方法讀取文件內(nèi)容時,文件必須是以r(只讀)或者r+(讀寫)方式打開。

例:

with open('test.txt','r',encoding='utf-8') as f:

txt=f.readlines()

print(txt)

運行結(jié)果:

['Python是一種解釋型語言: 這意味著開發(fā)過程中沒有了編譯這個環(huán)節(jié)。類似于PHP和Perl語言。 ', 'Python是交互式語言: 這意味著,您可以在一個 Python 提示符 后直接執(zhí)行代碼。 ', 'Python是面向?qū)ο笳Z言: 這意味著Python支持面向?qū)ο蟮娘L格或代碼封裝在對象的編程技術(shù)。 ', 'Python是初學者的語言:Python 對初級程序員而言,是一種偉大的語言,它支持廣泛的應(yīng)用程序開發(fā)。 ']

從上面的運行結(jié)果可以看出,readlines()方法的返回值為一個字符串列表。所以,也可以以讀取列表元素的方法輸出。如下所示:

with open('test.txt','r',encoding='utf-8') as f:

txt=f.readlines()

for line in txt:

print(line,end='')

運行結(jié)果:

Python是一種解釋型語言: 這意味著開發(fā)過程中沒有了編譯這個環(huán)節(jié)。類似于PHP和Perl語言。

Python是交互式語言: 這意味著,您可以在一個 Python 提示符 后直接執(zhí)行代碼。

Python是面向?qū)ο笳Z言: 這意味著Python支持面向?qū)ο蟮娘L格或代碼封裝在對象的編程技術(shù)。

Python是初學者的語言:Python 對初級程序員而言,是一種偉大的語言,它支持廣泛的應(yīng)用程序開發(fā)。

15.5 寫入文件內(nèi)容

語法格式如下:

file.write(string)

其中,file為打開的文件對象,string為要寫入的字符串。

寫入文件內(nèi)容時,文件必須以w(可寫)或a(追加)模式打開。否則,會拋出如下異常提示:

Traceback (most recent call last):

File "C:UsersAdministratorAppDataLocalProgramsPythonPython383.py", line 2, in

f.write('人生苦短,我用Python!')

io.UnsupportedOperation: not writable

關(guān)于write()方法的用法舉例如下:

with open('test.txt','a',encoding='utf-8') as f:

f.write('人生苦短,我用Python!')

with open('test.txt','r',encoding='utf-8') as f:

txt=f.read()

print(txt)

運行結(jié)果:

Python是一種解釋型語言: 這意味著開發(fā)過程中沒有了編譯這個環(huán)節(jié)。類似于PHP和Perl語言。

Python是交互式語言: 這意味著,您可以在一個 Python 提示符 后直接執(zhí)行代碼。

Python是面向?qū)ο笳Z言: 這意味著Python支持面向?qū)ο蟮娘L格或代碼封裝在對象的編程技術(shù)。

Python是初學者的語言:Python 對初級程序員而言,是一種偉大的語言,它支持廣泛的應(yīng)用程序開發(fā)。

人生苦短,我用Python!

可以看出,由于文件的打開方式為a模式(追加模式),寫入的內(nèi)容被寫入到文件的末尾。

在Python中,文件操作方法里沒有類似于字符串內(nèi)的計算長度、查找、替換、截取、分隔等方法,為什么沒有?原因可能是文件的類型太復(fù)雜,譬如說二進制文件,上述操作的意義不大。如果僅僅要對文本文件進行上述操作,完全可以先把文件的內(nèi)容讀取到字符串中,再用相應(yīng)的字符串函數(shù)或方法去操作就可以了。譬如,要將test.txt文件中的字符串‘Python’替換為’PHP’,則可以用如下代碼完成:

txt1=''

with open('test.txt','r',encoding='utf-8') as f:

txt1=f.read() #先將文件內(nèi)容存入字符串txt1中

txt2=txt1.replace('Python','PHP') #將txt1中的'Python'替換為'PHP',并存入txt2

with open('test.txt','w',encoding='utf-8') as f:

f.write(txt2) #將字符串txt2的內(nèi)容寫回到文件中

這里之所以分兩步打開文件(第一次為r模式,第二次為w模式),而沒有采用一次讀寫(r+、w+方式),因為那樣比較容易出錯。實踐證明,將文件的讀操作和寫操作分開其實是非常正確的選擇。

分享名稱:抽獎函數(shù)python讀寫,用python寫抽獎程序
網(wǎng)站地址:http://chinadenli.net/article20/dsicsjo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號動態(tài)網(wǎng)站域名注冊Google定制開發(fā)App開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)