Библиотека knigago >> Компьютеры: Разработка ПО >> Программирование: прочее >> Приложение к «Python в библиотеке»

w cat (w_cat) - Приложение к «Python в библиотеке»

Приложение к «Python в библиотеке»
Книга - Приложение к «Python в библиотеке».  w cat (w_cat)  - прочитать полностью в библиотеке КнигаГо
Название:
Приложение к «Python в библиотеке»
w cat (w_cat)

Жанр:

Самиздат, сетевая литература, Программирование: прочее, Python

Изадано в серии:

неизвестно

Издательство:

неизвестно

Год издания:

-

ISBN:

неизвестно

Отзывы:

Комментировать

Рейтинг:

Поделись книгой с друзьями!

Помощь сайту: донат на оплату сервера

Краткое содержание книги "Приложение к «Python в библиотеке»"

Запустив скрипт «fb2_dir.py» Вы извлечете из файла исходники сакриптов.

Читаем онлайн "Приложение к «Python в библиотеке»". [Страница - 2]

m_dir import parse_dir

Capture = ''

FileName = ''

def parse_zip(fn):

, ,global FileName

# , ,print >> sys.stderr, 'Zip:', os.path.basename(fn)

, ,FileName = fn

, ,z = zipfile.ZipFile(fn, 'r')

, ,filelist = z.namelist()

, ,filelist.sort()

, ,for n in filelist:

, , , ,try:

, , , , , ,if n[-4:] == ".fb2":

, , , , , , , ,parse_fb2(z.open(n))

, , , ,except:

# , , , , , ,print >> sys.stderr, 'X15:', n

, , , , , ,print( "X15:", n )

def parse_fb2(fn):

, ,global Capture

, ,if isinstance(fn, str):

, , , ,fn = open(fn)

, ,try:

, , , ,dom = xml.dom.minidom.parse(fn)

, ,except:

, , , ,print('Error:')

, , , ,print(FileName)

, ,else:

, , , ,dom.normalize()

, , , ,node1=dom.getElementsByTagName("description")[0]

, , , ,node1=node1.getElementsByTagName("title-info")[0]

, , , ,try:

, , , , , ,node1=node1.getElementsByTagName("author")[0]

, , , , , ,node1=node1.getElementsByTagName("last-name")[0]

, , , , , ,s = node1.childNodes[0].nodeValue

, , , , , ,s = s.encode("utf-8")

, , , , , ,Capture = s.capitalize()

, , , ,except:

, , , , , ,Capture = "noname"

, , , ,FindValue(Capture, FileName)

def parse_file(fn):

, ,global FileName

, ,FileName = fn

, ,m = fn.split(".")[-1]

, ,if (m == "zip"):

, , , ,parse_zip(fn)

, ,elif (m == "fb2"):

, , , ,parse_fb2(fn)

, , , ,

def parse_dir(fn):

, ,dirlist = os.listdir(fn)

, ,dirlist.sort()

, ,for i in dirlist:

, , , ,if os.path.getsize(i) > 0:

, , , , , ,parse_file(os.path.join(fn, i))

#? , , , ,else:

#? , , , , , ,print("bad zip "+ i)

#--------------------------------------------------

#from sort import path, mySorting

path = os.getcwd()

def mPrintList(oldn, M):

, ,global path

, ,ss = str(oldn, encoding='utf-8')

# , ,ss = path+"/"+s.encode("utf-8")

# , ,print(s)

, ,if (not os.path.isdir(ss)):

# , , , ,print(ss)

, , , ,os.mkdir(ss)

, ,for k in M:

, , , ,if (not os.path.isfile(ss)):

# , , , , , ,print(ss)

, , , , , ,

, , , , , ,shutil.move(k, ss)

# , , , ,print(ss)

# , , , ,shutil.move(k, ss)

, , , ,

def mySorting():

, ,global Books

, ,old_name = Books[len(Books)-1][0]

, ,flag = 0

, ,for i in range(len(Books)-1, 0, -1):

, , , , if flag == 0 and Books[i-1][0] == old_name:

, , , , , , flag = 1

, , , , , , L = []

, , , , , , L.append(Books[i][1])

, , , , , , Books.pop(i)

, , , , , ,

, , , , if flag == 1:

, , , , , , if Books[i-1][0] == old_name:

, , , , , , , ,L.append(Books[i-1][1])

, , , , , , , ,Books.pop(i-1)

, , , , , , else:

, , , , , , , , mPrintList(old_name, L)

, , , , , , , , old_name = Books[i-1][0]

, , , , , , , , flag = 0

, , , , else:

, , , , , , old_name = Books[i-1][0]

, ,

, ,if flag == 1:

, , , ,mPrintList(old_name, L)

, , , ,

#----------------------------------------

def mMain():

mySorting()

fbName = "f"

fNum = 1

fName = fbName + str(fNum) #'f1'

num = 0

if len(Books) > 0:

, , if (not os.path.isdir(fName)):

, , , , os.mkdir(fName)

, , for i in Books:

, , , , if (not os.path.isfile(path+"/"+fName)):

, , , , , , shutil.move(i[1], path+"/"+fName)

, , , , num += 1

, , , , if num == 9: # number in folder !!!

, , , , , , fNum += 1

, , , , , , fName = fbName + str(fNum)

, , , , , , if (not os.path.isdir(fName)):

, , , , , , , , os.mkdir(fName)

, , , , , , num = 0

print( 'Done!')

#--------------------------------------------------

parse_dir(path)

if len(Books) == 0:

, ,print('Empty dir')

else:

, ,mMain()

6

fb2err4.py

#!/usr/bin/env python

# -*- codning: utf-8 -*-

import sys, os

# проверка структуры файла fb2

#----------------------------------------------

file = 'lib.fb2'

#count = 1 # счетчик строк

flag = False # признак анализа тега

S = '' # место для обработанного тега

Tag = '' # место для тега

L = [] # стек

Tagss = []

'''

with open(file, encoding="utf8") as f:

, ,LList = f.readlines()

for i in LList:

, ,count += 1

, ,if i.find('section') > -1:

, , , ,print(count)

, , , ,print(i)

f.close()

'''

def printStack():

, ,st = open("stack.txt", "w")

, ,for n in Tagss:

, , , ,#print(n) # вывод на этран

, , , ,st.write(n+'\n') # или вывод в файл

, ,st.close()

def run_analiz(fn):

, ,count = 1 # счетчик строк

, ,if not os.path.isfile(fn): # проверка существования файла

, , , ,print('"'+fn+'" file does not exist.')

, , , ,return

, ,

, ,global Tagss

, ,f = open(fn, 'rb') #

, ,d = f.read()

, ,for n in d:

, , , ,if n == 10: # символ завершения строки

, , , , , ,count += 1 # + в счетчик строк

, , , ,elif chr(n) == '<': # начало тега

, , , , , ,flag = True

, , , , , ,Tag = '' # подготовка места для тега

, , , ,else:

, , , , , ,if flag: # читаем тег

, , , , , , , ,if chr(n) == '>': # провека на конец тега, если да:

, , , , , , , , , ,S = Tag.split(' ')[0] # отбрасывание возможных параметров

, , , , , , , , , ,flag = False

, , , , , , , , , ,if S[0] == '/': # проверка на закрывающий тег

, , , , , , , , , , , ,Tagss.append(str(count)+' <'+S)

, , , , , , , , , , , ,S = S[1:] # удаление слеша

, , , , , , , , , , , ,Lo = L.pop() # чтение из стека

, , , , , , , , , , , ,if Lo[0] != S: # сообщение об ошибке

, , , , , , , , , , , , , ,printStack() # распечатка стека

, , , , , , , , , , , , , , # ежели такая распечатка не нужна - закомментируйте

, , , , , , , , , , , , , ,print('Teg = "'+Lo[0]+'" begin in str = '+ str(Lo[1]))

, , , , , , , , , , , , , ,print('Не соответствует')

, , , , , , , , , , , , , ,print('Teg ="' +S+ '"end in str = '+ str(count))

, , , , , , , , , , , , , ,f.close()

, , , , , , , , , , , , , ,return

, , , , , , , , , ,else:

, , , , , , , , , , , ,if Tag[-1] != '/': # обработка одинарных тегов

, , , , , , , , , , , , , ,T = Tag.split(' ')

, , , , , , , , , , , , , ,Tagss.append(str(count)+' <'+T[0])

, , , , , , , , , , , , , ,Lo = [S, count] # подготовка для записи в стек

, , , , , , , , , , , , , ,L.append(Lo) # запись в стек

, , , , , , , ,else:

, , , , , , , , , ,Tag = Tag + chr(n) # добавление символа к тегу

, ,f.close()

, ,print('OK!!!') # сообщение об удачной проверке.

while True: # бесконечный цикл проверок

FN = input('Введите имя файла: ['+file+']')

if FN == '': # если сразу нажат "Enter"

, , run_analiz(file) # повторяем проверку файла

else:

, , file = FN # запоминаем --">

Оставить комментарий:


Ваш e-mail является приватным и не будет опубликован в комментарии.