用python將多個文檔合成一個


可以參考下以下網址(讀寫文件):https://www.liaoxuefeng.com/wiki/001374738125095c955c1e6d8bb493182103fac9270762a000/001386820066616a77f826d876b46b9ac34cb5f34374f7a000

Python:文件的讀取、創建、追加、刪除、清空

 

一、用Python創建一個新文件,內容是從0到9的整數, 每個數字占一行:

#python
>>>f=open('f.txt','w')    # r只讀,w可寫,a追加
>>>for i in range(0,10):f.write(str(i)+'\n')
>>> f.close()

二、文件內容追加,從0到9的10個隨機整數:

>>>import random
>>>f=open('f.txt','a')
>>>for i in range(0,10):f.write(str(random.randint(0,9)))
>>>f.write('\n')
>>>f.close()

三、文件內容追加,從0到9的隨機整數, 10個數字一行,共10行:

>>> import random
>>> f=open('f.txt','a')
>>> for i in range(0,10):
.  .  .     for i in range(0,10):f.write(str(random.randint(0,9))) 
.  .  .     f.write('\n')    
.  .  .
>>> f.close()

四、把標准輸出定向到文件:

>>> import sys
>>> sys.stdout = open("stdout.txt", "w")
>>>  . . .

五、文件的讀寫
一、文件打開:
f = file(name[, mode[, buffering]])

入口參數:   name 文件名
                  mode   選項,字符串
                  buffering   是否緩沖 (0=不緩沖,1=緩沖, >1的int數=緩沖區大小)
返回值 : 文件對象
mode 選項:
"r"   以讀方式打開,只能讀文件 , 如果文件不存在,會發生異常      
"w" 以寫方式打開,只能寫文件, 如果文件不存在,創建該文件,如果文件已存在,先清空,再打開文件
"rb"   以二進制讀方式打開,只能讀文件 , 如果文件不存在,會發生異常      
"wb" 以二進制寫方式打開,只能寫文件, 如果文件不存在,創建該文件,如果文件已存在,先清空,再打開文件
"rt"   以文本讀方式打開,只能讀文件 , 如果文件不存在,會發生異常      
"wt" 以文本寫方式打開,只能寫文件, 如果文件不存在,創建該文件,如果文件已存在,先清空,再打開文件
"rb+"   以二進制讀方式打開,可以讀、寫文件 , 如果文件不存在,會發生異常      
"wb+" 以二進制寫方式打開,可以讀、寫文件, 如果文件不存在,創建該文件,如果文件已存在,先清空,再打開文件


二、關閉文件
f.close()
當文件讀寫完畢后,應關閉文件。


三、清空文件內容
f.truncate()
注意:僅當以 "r+"   "rb+"    "w"   "wb" "wb+"等以可寫模式打開的文件才可以執行該功能。


四、文件的指針定位與查詢
(1)文件指針:
      文件被打開后,其對象保存在 f 中, 它會記住文件的當前位置,以便於執行讀、寫操作,這個位置稱為文件的指針( 一個從文件頭部開始計算的字節數 long 類型 )。
(2)文件打開時的位置:
      以"r"   "r+"   "rb+" 讀方式, "w"   "w+"   "wb+"寫方式 打開的文件,一開始,文件指針均指向文件的頭部。
(3) 獲取文件指針的值:
      L = f.tell()
(4) 移動文件的指針
       f.seek(   偏移量, 選項 )
      選項 =0 時, 表示將文件指針指向從文件頭部到 "偏移量"字節處。
      選項 =1 時, 表示將文件指針指向從文件的當前位置,向后移動 "偏移量"字節。
      選項 =2 時, 表示將文件指針指向從文件的尾部,,向前移動 "偏移量"字節。


五、從文件讀取指內容   
1 文本文件(以"rt"方式打開的文件)的讀取  
       s = f.readline(     )
        返回值: s 是字符串,從文件中讀取的一行,含行結束符。
        說明: (1)  如果 len( s ) =0 表示已到文件尾
                    (2)   如果是文件的最后一行,有可能沒有行結束符
2 二進制文件(以"rb"、"rb+"、"wb+" 方式打開的文件)的讀取  
          s = f.read(    n )
     說明: (1)  如果 len( s ) =0 表示已到文件尾
               (2)   文件讀取后,文件的指針向后移動 len(s) 字節。
             (3)如果磁道已壞,會發生異常。


六、向文件寫入一個字符串   
    f.write(    s )
    參數:       s 要寫入的字符串
    說明: (1)文件寫入后,文件的指針向后移動 len(s) 字節。
                 (2)如果磁道已壞,或磁盤已滿會發生異常。
返回值: s 是字符串,從文件中讀取的內容

七、刪除文件
import os
os.remove(file)

這個是轉自http://www.open-open.com/lib/view/open1413527388231.html

接下來是將多個文檔合並成一個文檔的程序

import numpy as np
import os,re,time,logging
class loadFolders(object):   # 迭代器
    def __init__(self,par_path):
        self.par_path = par_path
    def __iter__(self):
        for file in os.listdir(self.par_path):
            file_abspath = os.path.join(self.par_path, file)
            if os.path.isdir(file_abspath): # if file is a folder
                yield file_abspath
class loadFiles(object):
    def __init__(self,par_path):
        self.par_path = par_path
    def __iter__(self):
        folders = loadFolders(self.par_path)
        for folder in folders:              # level directory
            #catg = folder.split(os.sep)[-1]
            for file in os.listdir(folder):     # secondary directory
                file_path = os.path.join(folder,file)
                if os.path.isfile(file_path):
                    this_file = open(file_path,'rb')
                    content = this_file.read().decode('utf8')
                    yield re.sub(r'\s{2,}', '', content)
                    this_file.close()
if __name__=='__main__':
     path_doc_root = 'F:\\THUCNews\\chinesenew'
     n=10
     f=open("F:\\THUCNews\\chinesenew\\財經.txt",'w',encoding='utf-8')
     files = loadFiles(path_doc_root)
     for msg in files:
         f.write(msg+'\n')
f.close()

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM