黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

python分割文件的常用方法

系統(tǒng) 1951 0

本文大家整理了一些比較好用的關(guān)于python分割文件的方法,方法非常的簡(jiǎn)單實(shí)用。分享給大家供大家參考。具體如下:

例子1 指定分割文件大小

配置文件 config.ini:

復(fù)制代碼 代碼如下:
[global]
#原文件存放目錄
dir1=F:\work\python\3595\pyserver\test
#新文件存放目錄
dir2=F:\work\python\3595\pyserver\test1

python 代碼如下:

復(fù)制代碼 代碼如下:
#!/usr/bin/python
# -*- coding: utf-8 -*-
import os,sys,ConfigParser
class file_openate(object):
def __init__(self):
??? #初如化讀取數(shù)據(jù)庫(kù)配置
??? dir_config = ConfigParser.ConfigParser()
??? file_config=open('config.ini',"rb")
??? dir_config.readfp(file_config)
??? self.dir1=str(dir_config.get("global","dir1"))
??? self.dir1=unicode(self.dir1,'utf8')
??? self.dir2=str(dir_config.get("global","dir2"))
??? self.dir2=unicode(self.dir2,'utf8')
??? file_config.close()
#print self.dir2
#self.dir1="F:\\work\\python\\3595\\pyserver\\test"
def file_list(self):
??? input_name_han="軟件有不確認(rèn)性,前期使用最好先備份,以免發(fā)生數(shù)據(jù)丟失,確認(rèn)備份后,請(qǐng)輸入要分割的字節(jié)大小,按b來(lái)計(jì)算".decode('utf-8')
??? print input_name_han
??? while 1:
input_name=raw_input("number:")
if input_name.isdigit():
??? input_name=int(input_name)
??? os.chdir(self.dir1)
??? for filename in os.listdir(self.dir1):
os.chdir(self.dir1)
#print filename
name, ext = os.path.splitext(filename)
file_size=int(os.path.getsize(filename))
f=open(filename,'r')
chu_nmuber=0
while file_size >= 1:
??? #print file_size
??? chu_nmuber=chu_nmuber + 1
??? if file_size >= input_name:
file_size=file_size - input_name
a=f.read(input_name)
os.chdir(self.dir2)
filename1=name + '-' + str(chu_nmuber) + ext
new_f=open(filename1,'a')
new_f.write(a)
new_f.close()
#print file_size
??? else:
a=f.read()
os.chdir(self.dir2)
filename1=name + '-' + str(chu_nmuber) + ext
new_f=open(filename1,'a')
new_f.write(a)
new_f.close()
break
print "分割成功".decode('utf-8') + filename
f.close()
else:
??? print "請(qǐng)輸入正確的數(shù)字,請(qǐng)重新輸入".decode('utf-8')
file_name=file_openate()
file_name.file_list()

例子2,按行分割文件大小

復(fù)制代碼 代碼如下:
#!/usr/bin/env python
#--*-- coding:utf-8 --*--
import os
class SplitFiles():
??? """按行分割文件"""
??? def __init__(self, file_name, line_count=200):
??????? """初始化要分割的源文件名和分割后的文件行數(shù)"""
??????? self.file_name = file_name
??????? self.line_count = line_count
??? def split_file(self):
??????? if self.file_name and os.path.exists(self.file_name):
??????????? try:
??????????????? with open(self.file_name) as f : # 使用with讀文件
??????????????????? temp_count = 0
??????????????????? temp_content = []
??????????????????? part_num = 1
??????????????????? for line in f:
??????????????????????? if temp_count < self.line_count:
??????????????????????????? temp_count += 1
??????????????????????? else :
??????????????????????????? self.write_file(part_num, temp_content)
??????????????????????????? part_num += 1
??????????????????????????? temp_count = 1
??????????????????????????? temp_content = []
??????????????????????? temp_content.append(line)
??????????????????? else : # 正常結(jié)束循環(huán)后將剩余的內(nèi)容寫入新文件中
??????????????????????? self.write_file(part_num, temp_content)
??????????? except IOError as err:
??????????????? print(err)
??????? else:
??????????? print("%s is not a validate file" % self.file_name)
??? def get_part_file_name(self, part_num):
??????? """"獲取分割后的文件名稱:在源文件相同目錄下建立臨時(shí)文件夾temp_part_file,然后將分割后的文件放到該路徑下"""
??????? temp_path = os.path.dirname(self.file_name) # 獲取文件的路徑(不含文件名)
??????? part_file_name = temp_path + "temp_part_file"
??????? if not os.path.exists(temp_path) : # 如果臨時(shí)目錄不存在則創(chuàng)建
??????????? os.makedirs(temp_path)
??????? part_file_name += os.sep + "temp_file_" + str(part_num) + ".part"
??????? return part_file_name
??? def write_file(self, part_num, *line_content):
??????? """將按行分割后的內(nèi)容寫入相應(yīng)的分割文件中"""
??????? part_file_name = self.get_part_file_name(part_num)
??????? print(line_content)
??????? try :
??????????? with open(part_file_name, "w") as part_file:
??????????????? part_file.writelines(line_content[0])
??????? except IOError as err:
??????????? print(err)
if __name__ == "__main__":
??? sf = SplitFiles(r"F:\multiple_thread_read_file.txt")
??? sf.split_file()

上面只是進(jìn)行了分割了,如果我們又要合并怎么辦呢?下面這個(gè)例子可以實(shí)現(xiàn)分割與合并哦,大家一起看看。

例子3, 分割文件與合并函數(shù)

復(fù)制代碼 代碼如下:
#!/usr/bin/python
##########################################################################
# split a file into a set of parts; join.py puts them back together;
# this is a customizable version of the standard unix split command-line
# utility; because it is written in Python, it also works on Windows and
# can be easily modified; because it exports a function, its logic can
# also be imported and reused in other applications;
##########################################################################
?????
import sys, os
kilobytes = 1024
megabytes = kilobytes * 1000
chunksize = int(1.4 * megabytes)?? # default: roughly a floppy
?????
def split(fromfile, todir, chunksize=chunksize):
??? if not os.path.exists(todir):? # caller handles errors
os.mkdir(todir)??? # make dir, read/write parts
??? else:
for fname in os.listdir(todir):??? # delete any existing files
??? os.remove(os.path.join(todir, fname))
??? partnum = 0
??? input = open(fromfile, 'rb')?? # use binary mode on Windows
??? while 1:?????? # eof=empty string from read
chunk = input.read(chunksize)????? # get next part <= chunksize
if not chunk: break
partnum? = partnum+1
filename = os.path.join(todir, ('part%04d' % partnum))
fileobj? = open(filename, 'wb')
fileobj.write(chunk)
fileobj.close()??? # or simply open().write()
??? input.close()
??? assert partnum <= 9999 # join sort fails if 5 digits
??? return partnum
????
if __name__ == '__main__':
??? if len(sys.argv) == 2 and sys.argv[1] == '-help':
print 'Use: split.py [file-to-split target-dir [chunksize]]'
??? else:
if len(sys.argv) < 3:
??? interactive = 1
??? fromfile = raw_input('File to be split? ')?????? # input if clicked
??? todir??? = raw_input('Directory to store part files? ')
else:
??? interactive = 0
??? fromfile, todir = sys.argv[1:3]? # args in cmdline
??? if len(sys.argv) == 4: chunksize = int(sys.argv[3])
absfrom, absto = map(os.path.abspath, [fromfile, todir])
print 'Splitting', absfrom, 'to', absto, 'by', chunksize
?????
try:
??? parts = split(fromfile, todir, chunksize)
except:
??? print 'Error during split:'
??? print sys.exc_info()[0], sys.exc_info()[1]
else:
??? print 'Split finished:', parts, 'parts are in', absto
if interactive: raw_input('Press Enter key') # pause if clicked

join_file.py
?

復(fù)制代碼 代碼如下:
#!/usr/bin/python
##########################################################################
# join all part files in a dir created by split.py, to recreate file.?
# This is roughly like a 'cat fromdir/* > tofile' command on unix, but is
# more portable and configurable, and exports the join operation as a
# reusable function.? Relies on sort order of file names: must be same
# length.? Could extend split/join to popup Tkinter file selectors.
##########################################################################
?????
import os, sys
readsize = 1024
?????
def join(fromdir, tofile):
??? output = open(tofile, 'wb')
??? parts? = os.listdir(fromdir)
??? parts.sort()
??? for filename in parts:
filepath = os.path.join(fromdir, filename)
fileobj? = open(filepath, 'rb')
while 1:
??? filebytes = fileobj.read(readsize)
??? if not filebytes: break
??? output.write(filebytes)
fileobj.close()
??? output.close()
?????
if __name__ == '__main__':
??? if len(sys.argv) == 2 and sys.argv[1] == '-help':
print 'Use: join.py [from-dir-name to-file-name]'
??? else:
if len(sys.argv) != 3:
??? interactive = 1
??? fromdir = raw_input('Directory containing part files? ')
??? tofile? = raw_input('Name of file to be recreated? ')
else:
??? interactive = 0
??? fromdir, tofile = sys.argv[1:]
absfrom, absto = map(os.path.abspath, [fromdir, tofile])
print 'Joining', absfrom, 'to make', absto
?????
try:
??? join(fromdir, tofile)
except:
??? print 'Error joining files:'
??? print sys.exc_info()[0], sys.exc_info()[1]
else:
?? print 'Join complete: see', absto
if interactive: raw_input('Press Enter key') # pause if clicked

希望本文所述對(duì)大家的Python程序設(shè)計(jì)有所幫助。


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論