-
Notifications
You must be signed in to change notification settings - Fork 0
/
file.py
80 lines (79 loc) · 2.83 KB
/
file.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#!/usr/bin/python3.6
# -*- coding: utf-8 -*-
from sys import argv
import textFct
from fileCls import File, Article
import loggerFct as log
help ="""traiter des fichiers
utilisation
le script est appelable dans un fichier
python3 fileClass.py fichier tag (fichierB)
les valeurs de tag
clean (ru - r - u): nettoyer le texte. modifier ou pas la casse.
mef (ru): mettre en forme un texte utilisant ma mise en forme spécifique.
help: afficher l'aide d'un fichier python.
convert: transformer un fichier html en texte et vice-versa.
md: transformer un fichier txt en markdown
comp: comparer deux fichiers
art: transformer un texte simple en article
inde: transformer un fichier html local en fichier adapté pour ma liseuse
pdf: mettre en forme le texte copié - collé d'un fichier pdf
"""
nbArg = len (argv)
if nbArg <3: print (help)
elif argv[2] == 'help':
from funcHelp import printHelp
printHelp (argv[1])
elif argv[2] == 'pdf':
page = File (argv[1])
page.read()
page.text = textFct.cleanPdf (page.text)
page.write()
elif argv[2] == 'art':
page = File (argv[1])
page.read()
article = Article (argv[1])
article.text = page.text
article.write()
elif argv[2] == 'md':
page = File (argv[1])
page.read()
page.toMarkdown()
page.write()
elif argv[1][-5:] == '.html' and argv[2] == 'inde':
page = Article (argv[1])
page.read()
page.write (True)
elif argv[2] == 'convert':
page = Article (argv[1])
page.read()
if argv[1][-5:] == '.html': page = page.toText()
elif argv[1][-6:] == '.xhtml': page = page.toText()
elif argv[1][-4:] == '.txt': page = page.toHtml()
independant = False
if nbArg >3 and argv[3]: independant = True
page.write (independant)
elif nbArg >2 and argv[2] == 'comp':
fileA = File (argv[1])
fileA.read()
fileB = File (argv[3])
fileB.read()
fileA.comparer (fileB)
elif nbArg >2:
filePerso = File (argv[1])
filePerso.read()
if 'clean' in argv:
if filePerso.path[-5:] == '.html' or filePerso.path[-6:] == '.xhtml' or filePerso.path[-4:] == '.xml': filePerso.text = textFct.cleanHtml (filePerso.text)
# formats dérivés du xml
elif filePerso.path[-4:] == '.ops' or filePerso.path[-4:] == '.opf' or filePerso.path[-4:] == '.ncx': filePerso.text = textFct.cleanHtml (filePerso.text)
elif filePerso.path[-4:] == '.css': filePerso.text = textFct.cleanCss (filePerso.text)
else: filePerso.text = textFct.cleanText (filePerso.text)
elif 'mef' in argv: filePerso.text = textFct.shape (filePerso.text)
if nbArg >3:
# rajouter un argument afin d'empêcher l'écriture des majuscules
if 'r' in argv[3] and 'u' in argv[3]: filePerso.text = textFct.upperCase (filePerso.text, 'reset upper')
elif 'r' in argv[3]: filePerso.text = textFct.upperCase (filePerso.text, 'reset')
elif 'u' in argv[3]: filePerso.text = textFct.upperCase (filePerso.text, 'upper')
filePerso.write()
# le nom du fichier n'a pas ete donne
else: print (help)