国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python3中簡單的文件操作及兩個簡單小實例分享

2020-01-04 17:21:19
字體:
來源:轉載
供稿:網友

前言

首先介紹一下什么叫做相對路徑和絕對路徑,我們程序狗家族想必都是懂這個的,但是難免會有童鞋忘記。所以碼出來供大家快速回憶一下。

相對路徑

相對路徑是相對于文件當前的工作路徑而言的

絕對路徑

絕對路徑是由文件名和它的完整路徑以及驅動器字母組成的,如果是Windows系統,那么某一個文件的絕對路徑可能是:

c:/python/103186.html">pythonworkspace/firstpy.py

在Unix平臺上,文件的絕對路徑可能是: /home/sherlockblaze/Documents/pythonworkspace/firstpy.py

文件類型

文件大概可以分為文本文件和二進制文件。在不同操作系統下,可以用文本編輯器編輯的文件,都稱為文本文件,那么其他的文件就屬于二進制文件。而二進制文件相比與文本文件的優勢在于二進制文件的處理效率更高一些。

讀取文件的開始

讀取一個文件的思路永遠都是相同的,第一步自然就是打開一個文件。在python中我們通過如下代碼使用open函數來打開一個文件。

input = open(filepath,mode)

我們的mode主要由以下幾種方式。

 

模式 作用
r 讀取模式
w 寫入模式
a 追加模式
rb 讀取二進制數據模式打開文件
wb 寫入二進制數據模式打開文件

 

同樣我們有兩種途徑來打開文件。

通過絕對路徑

input = open("/Users/sherlockblaze/Documents/pythonworkspace/Test.txt","r")

通過相對路徑(需要注意的是,我們通過相對路徑是可以打開當前工作目錄下的文件的,也就是說如果我的.py文件存在 /User/sherlock/Documents 下的話,我們通過相對路徑打開的文件也同樣存在當前路徑下)

input = open("Test.txt","r")

注意

在Windows下我們通過絕對路徑來打開文件的時候,我們需要在絕對文件名前加上一個 r 前綴,來表示這個字符串是一個行字符串,這樣可以讓python解釋器將文件中的反斜線理解成字面意義上的反斜線。例如:

input = open(r"d:/pythonworkspace/Test.txt","r")

如果我們不添加 r 作為前綴,則需要用轉義字符把上面的語句修改成如下所示:

input = open("d://pythonworkspace//Test.txt","r")

向文件中寫入數據

我們首先通過寫入的方式打開文件,然后通過調用write方法,向文件中寫入數據。

def main(): input = open("Test.txt","w") input.write("SherlockBlaze") input.write("/t is the most handsome guy!/n") input.close() main()

通過這種方式,我們往當前目錄下的 Test.txt 文件中寫入了 SherlockBlaze is the most handsome guy! 這句話,并且需要注意的是,我們在寫完文件后,調用close()方法關閉了文件流。

常見小特性

當使用w模式打開一個文件時,如果文件不存在,open函數就會創建一個新文件,如果該文件存在,那么這個文件里的內容會被心的內容覆蓋。當我們用讀/寫模式打開文件的時候,文件內部會添加一個叫做文件指針的特殊標記,文件的讀寫操作都發生在指針當前位置上。

判斷文件是否存在

為了避免誤操作,我們可以通過os.path模塊中的isFile函數來判斷一個文件是否存在。即:

import os.pathis os.paht.isfile("Test.txt"): print("Test.txt exists")else: print("Test.txt doesn't exists")

簡單小程序

輸入文件路徑,并且從中計算各個字母出現的次數

def main(): filename = input("Enter a filename: ").strip() infile = open(filename,"r") counts = 26 * [0] for line in infile: countLetters(line.lower(),counts) for i in range(len(counts)): if counts[i] != 0: print(chr(ord('a') + i) + "appears " + str(counts[i]) + (" time" if counts[i] == 1 else " times")) infile.close()def countLetters(line,counts): for ch in line: if ch.isalpha(): counts[ord(ch) - ord('a')] += 1main()

思路簡單敘述:首先創建數組,每當讀取到一個字符,對對應位置的數字進行加一,最后在進行遍歷得到輸出。

下載網站源代碼,然后寫入目的文件中

import sysimport urllibimport urllib.requestimport os.pathdef download(url,num_retries = 2): print ('Downloading:',url) try: html = urllib.request.urlopen(url).read() except urllib.URLError as e: print ('Download error:',e.reason) html = None if num_retries > 0: if hasattr(e,'code') and 500 <= e.code <600: return download(url,num_retries-1) return htmldef main(): url = input("Enter a url:/n").strip() f2 = input("Enter a target file:/n").strip() if os.path.isfile(f2): print(f2 + " already exists") sys.exit() html = download(url) target = open(f2,"w") content = html.decode(encoding="utf-8") target.write(content) target.close()main()

比如我輸入網址 http://wmeiwen.vevb.com/,在輸入目的文件:game2.txt。即可進行下載并把對應html輸入到當前工作目錄的game2.txt文件中。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 抚顺市| 财经| 张掖市| 英超| 剑阁县| 防城港市| 石河子市| 南投市| 平武县| 越西县| 玉龙| 珲春市| 营山县| 巴东县| 云霄县| 林西县| 古浪县| 镇沅| 通州区| 若羌县| 浦江县| 麦盖提县| 达州市| 明光市| 社旗县| 离岛区| 辽阳市| 峡江县| 勃利县| 黎平县| 洛阳市| 南阳市| 花垣县| 隆昌县| 永嘉县| 额尔古纳市| 枞阳县| 长寿区| 若羌县| 拜城县| 高尔夫|