1. 程式人生 > 其它 >Java網路 1.13 HTML雜項

Java網路 1.13 HTML雜項

open/檔案操作
f=open('/tmp/hello','w')

#open(路徑+檔名,讀寫模式)

#讀寫模式:r只讀,r+讀寫,w新建(會覆蓋原有檔案),a追加,b二進位制檔案.常用模式

如:'rb','wb','r+b'等等

讀寫模式的型別有:

rU 或 Ua 以讀方式開啟, 同時提供通用換行符支援 (PEP 278)
w以寫方式開啟,
a以追加模式開啟 (從 EOF 開始, 必要時建立新檔案)
r+以讀寫模式開啟
w+以讀寫模式開啟 (參見 w )
a+以讀寫模式開啟 (參見 a )
rb以二進位制讀模式開啟
wb以二進位制寫模式開啟 (參見 w )
ab以二進位制追加模式開啟 (參見 a )
rb+以二進位制讀寫模式開啟 (參見 r+ )
wb+以二進位制讀寫模式開啟 (參見 w+ )
ab+以二進位制讀寫模式開啟 (參見 a+ )


注意:

1、使用'W',檔案若存在,首先要清空,然後(重新)建立,

2、使用'a'模式 ,把所有要寫入檔案的資料都追加到檔案的末尾,即使你使用了seek()指向檔案的其他地方,如果檔案不存在,將自動被建立。



f.read([size]) size未指定則返回整個檔案,如果檔案大小>2倍記憶體則有問題.f.read()讀到檔案尾時返回""(空字串)

file.readline() 返回一行

file.readline([size]) 返回包含size行的列表,size 未指定則返回全部行

for line in f: print line #通過迭代器訪問

f.write("hello\n") #如果要寫入字串以外的資料,先將他轉換為字串.

f.tell() 返回一個整數,表示當前檔案指標的位置(就是到檔案頭的位元數).

f.seek(偏移量,[起始位置])

用來移動檔案指標

偏移量:單位:位元,可正可負

起始位置:0-檔案頭,預設值;1-當前位置;2-檔案尾

f.close() 關閉檔案

--------------------------------------------------

檔案:資料的抽象和集合

  • 檔案是儲存在輔助儲存器上的資料序列
  • 檔案是資料儲存的一種形式
  • 檔案展現形態:文字檔案和二進位制檔案

文字檔案 VS. 二進位制檔案

  • 檔案檔案和二進位制檔案只是檔案的展示方式
  • 本質上,所有檔案都是二進位制形式儲存
  • 形式上,所有檔案採用兩種方式展示

文字檔案

  • 由單一特定編碼組成的檔案,如UTF-8編碼
  • 由於存在編碼,也被看成是儲存著的長字串
  • 適用於例如:.txt檔案、.py檔案等

二進位制檔案

  • 直接由位元0和1組成,沒有統一字元編碼
  • 一般存在二進位制0和1的組織結構,即檔案格式
  • 適用於例如:.png檔案、.avi檔案等

檔案的開啟關閉

檔案處理的步驟:開啟-操作-關閉

file_object = open("filename", "openmode")
... #操作
file_object.close()
with open("filename", "openmode") as file_object:
    ... #操作
  • filename:檔案路徑及名稱,當與原始檔同目錄是可省略路徑
  • openmode:開啟模式,文字or二進位制,讀or寫

開啟模式

openmodedetails
'r' 只讀模式,預設值,如果檔案不存在,返回FileNotFoundError
'w' 覆蓋寫模式,檔案不存在則建立,存在則完全覆蓋
'x' 建立寫模式,檔案不存在則建立,存在則返回FileExistsError
'a' 追加寫模式,檔案不存在則建立,存在則在檔案最後追加內容
'b' 二進位制檔案模式
't' 文字檔案模式,預設值
'+' 與r/w/x/a一同使用,在原功能基礎上增加同時讀寫功能

檔案內容的讀取

operationdetails
f.read(size=-1) 讀入全部內容,如果給出引數,讀入前size長度
f.readline(size=-1) 讀入一行內容,如果給出引數,讀入該行前size長度
f.readlines(hint=-1) 讀入檔案所有行,以每行為元素形成列表,如果給出引數,讀入前hint行
f.write(s) 向檔案寫入一個字串或位元組流
f.writelines(lines) 將一個元素全為字串的列表寫入檔案
f.seek(offset) 改變當前檔案操作指標的位置,offset含義如下:0 – 檔案開頭; 1 – 當前位置; 2 – 檔案結尾

檔案的全文字操作

一次讀入,統一處理

fo = open(fname,"r")
txt = fo.read() 
...#對全文txt進行處理
fo.close()

按數量讀入,逐步處理

fo = open(fname,"r")
txt = fo.read(2)
while txt != "":
    #對txt進行處理
    txt = fo.read(2)
fo.close()

檔案的逐行操作

一次讀入,分行處理

fo = open(fname,"r")
for line in fo.readlines():
    print(line)
fo.close()

分行讀入,逐行處理

fo = open(fname,"r")
for line in fo:
    print(line)
fo.close()

資料檔案的寫入

fo = open("output.txt","w+") 
ls = ["China", "France", "America"]
fo.writelines(ls)
fo.seek(0)
for line in fo:
    print(line)
fo.close()

使用json模組

.json檔案中儲存的資料結構為列表字典

json.dump()用來儲存資料到json檔案中,接受兩個實參:要儲存的資料和用於儲存資料的檔案物件

import json

numbers = [1, 2, 3, 4, 5, 6]
filename = 'number.json'
with open(filename, 'w') as f_obj:
    json.dump(numbers, f_obj)

則number.json檔案中的內容的格式與python中一樣,為列表[1, 2, 3, 4, 5, 6]

json.load()用來從json檔案讀取資料到記憶體中

import json

filename = 'number.json'
with open(filename, 'r') as f_obj:
    numbers = json.load(f_obj)

則numbers為列表[1, 2, 3, 4, 5, 6]

1. 初識檔案操作
2. 只讀(r, rb)
3. 只寫(w, wb)
4. 追加(a, ab)
5. r+讀寫
6. w+寫讀
7. a+寫讀(追加寫讀)
8. 其他操作方法
9. 檔案的修改以及另一種開啟檔案句柄的方式

< 完 >
轉載請註明原文連結:<https://www.cnblogs.com/tzhao/p/9855232.html>,謝謝!

python中對檔案、資料夾(檔案操作函式)的操作需要涉及到os模組和shutil模組。

得到當前工作目錄,即當前Python指令碼工作的目錄路徑: os.getcwd()

返回指定目錄下的所有檔案和目錄名:os.listdir()

函式用來刪除一個檔案:os.remove()

刪除多個目錄:os.removedirs(r“c:\python”)

檢驗給出的路徑是否是一個檔案:os.path.isfile()

檢驗給出的路徑是否是一個目錄:os.path.isdir()

判斷是否是絕對路徑:os.path.isabs()

檢查是否快捷方式os.path.islink ( filename)

檢驗給出的路徑是否真地存:os.path.exists()

返回一個路徑的目錄名和檔名:os.path.split() eg os.path.split('/home/swaroop/byte/code/poem.txt') 結果:('/home/swaroop/byte/code', 'poem.txt')

分離副檔名:os.path.splitext()

獲取路徑名:os.path.dirname()

獲取檔名:os.path.basename()

執行shell命令: os.system()

讀取和設定環境變數:os.getenv() 與os.putenv()

給出當前平臺使用的行終止符:os.linesep Windows使用'\r\n',Linux使用'\n'而Mac使用'\r'

指示你正在使用的平臺:os.name 對於Windows,它是'nt',而對於Linux/Unix使用者,它是'posix'

重新命名:os.rename(old, new)

建立多級目錄:os.makedirs(r“c:\python\test”)

建立單個目錄:os.mkdir(“test”)

獲取檔案屬性:os.stat(file)

修改檔案許可權與時間戳:os.chmod(file)

終止當前程序:os.exit()

獲取檔案大小:os.path.getsize(filename)


檔案操作:
os.mknod("test.txt") 建立空檔案
fp = open("test.txt",w) 直接開啟一個檔案,如果檔案不存在則建立檔案

關於open 模式:

w 以寫方式開啟,
a 以追加模式開啟 (從 EOF 開始, 必要時建立新檔案)
r+ 以讀寫模式開啟
w+ 以讀寫模式開啟 (參見 w )
a+ 以讀寫模式開啟 (參見 a )
rb 以二進位制讀模式開啟
wb 以二進位制寫模式開啟 (參見 w )
ab 以二進位制追加模式開啟 (參見 a )
rb+ 以二進位制讀寫模式開啟 (參見 r+ )
wb+ 以二進位制讀寫模式開啟 (參見 w+ )
ab+ 以二進位制讀寫模式開啟 (參見 a+ )

fp.read([size]) #size為讀取的長度,以byte為單位

fp.readline([size]) #讀一行,如果定義了size,有可能返回的只是一行的一部分

fp.readlines([size]) #把檔案每一行作為一個list的一個成員,並返回這個list。其實它的內部是通過迴圈呼叫readline()來實現的。如果提供size引數,size是表示讀取內容的總長,也就是說可能只讀到檔案的一部分。

fp.write(str) #把str寫到檔案中,write()並不會在str後加上一個換行符

fp.writelines(seq) #把seq的內容全部寫到檔案中(多行一次性寫入)。這個函式也只是忠實地寫入,不會在每行後面加上任何東西。

fp.close() #關閉檔案。python會在一個檔案不用後自動關閉檔案,不過這一功能沒有保證,最好還是養成自己關閉的習慣。 如果一個檔案在關閉後還對其進行操作會產生ValueError

fp.flush() #把緩衝區的內容寫入硬碟

fp.fileno() #返回一個長整型的”檔案標籤“

fp.isatty() #檔案是否是一個終端裝置檔案(unix系統中的)

fp.tell() #返回檔案操作標記的當前位置,以檔案的開頭為原點

fp.next() #返回下一行,並將檔案操作標記位移到下一行。把一個file用於for … in file這樣的語句時,就是呼叫next()函式來實現遍歷的。

fp.seek(offset[,whence]) #將檔案打操作標記移到offset的位置。這個offset一般是相對於檔案的開頭來計算的,一般為正數。但如果提供了whence引數就不一定了,whence可以為0表示從頭開始計算,1表示以當前位置為原點計算。2表示以檔案末尾為原點進行計算。需要注意,如果檔案以a或a+的模式開啟,每次進行寫操作時,檔案操作標記會自動返回到檔案末尾。

fp.truncate([size]) #把檔案裁成規定的大小,預設的是裁到當前檔案操作標記的位置。如果size比檔案的大小還要大,依據系統的不同可能是不改變檔案,也可能是用0把檔案補到相應的大小,也可能是以一些隨機的內容加上去。

目錄操作:
os.mkdir("file") 建立目錄
複製檔案:
shutil.copyfile("oldfile","newfile") oldfile和newfile都只能是檔案
shutil.copy("oldfile","newfile") oldfile只能是資料夾,newfile可以是檔案,也可以是目標目錄
複製資料夾:
shutil.copytree("olddir","newdir") olddir和newdir都只能是目錄,且newdir必須不存在
重新命名檔案(目錄)
os.rename("oldname","newname") 檔案或目錄都是使用這條命令
移動檔案(目錄)
shutil.move("oldpos","newpos")
刪除檔案
os.remove("file")
刪除目錄
os.rmdir("dir")只能刪除空目錄
shutil.rmtree("dir") 空目錄、有內容的目錄都可以刪
轉換目錄
os.chdir("path") 換路徑