Форум программистов, компьютерный форум, киберфорум
Python
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 04.03.2012
Сообщений: 16

Допилить быдлокод

20.02.2014, 16:29. Показов 1259. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Имеется менеджер закладок XML на Python

Кликните здесь для просмотра всего текста
Python
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
from PySide import QtCore, QtGui, QtXml
class XmlGenerator(object):
    def __init__(self, treeWidget):
        self.treeWidget = treeWidget
        self.out = QtCore.QTextStream()
 
    def write(self, device):
        self.out.setDevice(device)
        self.out.setCodec('UTF-8')
        self.out << '<?xml version="1.0" encoding="UTF-8"?>\n' \
                 << '<!DOCTYPE xml>\n' \
                 << '<xml version="1.0">\n'
 
        for i in range(self.treeWidget.topLevelItemCount()):
            self.generateItem(self.treeWidget.topLevelItem(i), 1)
 
        self.out << '</xml>\n'
        return True
 
    def indent(self, depth):
        IndentSize = 4
 
        return IndentSize * depth * ' '
 
    def escapedText(self, txt):
        result = txt
        result.replace('&', '&amp;')
        result.replace('<', '&lt;')
        result.replace('>', '&gt;')
        return result
 
    def escapedAttribute(self, txt):
        result = self.escapedText(txt)
        result.replace('"', '&quot;')
        return '"' + result + '"'
 
    def generateItem(self, item, depth):
        tagName = item.data(0, QtCore.Qt.UserRole)
        if tagName == 'folder':
            folded = (not self.treeWidget.isItemExpanded(item))
            self.out << self.indent(depth) << '<folder folded="'
            if folded:
                self.out << 'yes'
            else:
                self.out << 'no'
            self.out << '">\n' \
                     << self.indent(depth + 1) << '<title>' \
                     << self.escapedText(item.text(0)) \
                     << '</title>\n'
 
            for i in range(item.childCount()):
                self.generateItem(item.child(i), depth + 1)
 
            self.out << self.indent(depth) << '</folder>\n'
        elif tagName == 'bookmark':
            self.out << self.indent(depth) << '<bookmark'
            if item.text(1):
                self.out << ' href=' \
                         << self.escapedAttribute(item.text(1))
            self.out << '>\n' \
                     << self.indent(depth + 1) << '<title>' \
                     << self.escapedText(item.text(0)) \
                     << '</title>\n' \
                     << self.indent(depth) << '</bookmark>\n'
        elif tagName == 'separator':
            self.out << self.indent(depth) << '<separator/>\n'
 
 
class XmlHandler(QtXml.QXmlDefaultHandler):
    def __init__(self, treeWidget):
        super(XmlHandler, self).__init__()
 
        self.treeWidget = treeWidget
        self.folderIcon = QtGui.QIcon()
        self.bookmarkIcon = QtGui.QIcon()
        self.currentText = 'currentText_test'
        self.errorStr = 'errorText_test'
 
        self.item = None
        self.metXmlTag = False
 
        style = self.treeWidget.style()
 
        self.folderIcon.addPixmap(style.standardPixmap(QtGui.QStyle.SP_DirClosedIcon),
                QtGui.QIcon.Normal, QtGui.QIcon.Off)
        self.folderIcon.addPixmap(style.standardPixmap(QtGui.QStyle.SP_DirOpenIcon),
                QtGui.QIcon.Normal, QtGui.QIcon.On)
        self.bookmarkIcon.addPixmap(style.standardPixmap(QtGui.QStyle.SP_FileIcon))
 
    def startElement(self, namespaceURI, localName, qName, attributes):
        if not self.metXmlTag and qName != 'xml':
            self.errorStr = "The file is not an XML file."
            return False
 
        if qName == 'xml':
            version = attributes.value('version')
            if version and version != '1.0':
                self.errorStr = "The File is not an XML version 1.0 file."
                return False
            self.metXmlTag = True
        elif qName == 'folder':
            self.item = self.createChildItem(qName)
            self.item.setFlags(self.item.flags() | QtCore.Qt.ItemIsEditable)
            self.item.setIcon(0, self.folderIcon)
            self.item.setText(0, "Folder")
            folded = (attributes.value('folded') != 'no')
            self.treeWidget.setItemExpanded(self.item, (not folded))
        elif qName == 'bookmark':
            self.item = self.createChildItem(qName)
            self.item.setFlags(self.item.flags() | QtCore.Qt.ItemIsEditable)
            self.item.setIcon(0, self.bookmarkIcon)
            self.item.setText(0, "Unkown title")
            self.item.setText(1, attributes.value('href'))
        elif qName == 'separator':
            self.item = self.createChildItem(qName)
            self.item.setFlags(self.item.flags() & ~QtCore.Qt.ItemIsSelectable)
            self.item.setText(0, 30 * "\xb7")
 
        self.currentText = ''
        return True
 
    def endElement(self, namespaceURI, localName, qName):
        if qName == 'title':
            if self.item:
                self.item.setText(0, self.currentText)
        elif qName in ('folder', 'bookmark', 'separator'):
            self.item = self.item.parent()
 
        return True
 
    def characters(self, txt):
        self.currentText += txt
        return True
 
    def fatalError(self, exception):
        QtGui.QMessageBox.information(self.treeWidget.window(),
                "SAX Bookmarks",
                "Parse error at line %d, column %d:\n%s" % (exception.lineNumber(), exception.columnNumber(), exception.message()))
        return False
 
    def errorString(self):
        return self.errorStr
 
    def createChildItem(self, tagName):
        if self.item:
            childItem = QtGui.QTreeWidgetItem(self.item)
        else:
            childItem = QtGui.QTreeWidgetItem(self.treeWidget)
 
        childItem.setData(0, QtCore.Qt.UserRole, tagName)
        return childItem
 
 
class MainWindow(QtGui.QMainWindow):
    def __init__(self):
        super(MainWindow, self).__init__()
 
        self.treeWidget = QtGui.QTreeWidget()
        self.treeWidget.header().setResizeMode(QtGui.QHeaderView.Stretch)
        self.treeWidget.setHeaderLabels(("Title", "Value"))
        self.setCentralWidget(self.treeWidget)
 
        self.createActions()
        self.createMenus()
 
        self.statusBar().showMessage("Gotovo")
 
        self.setWindowTitle("SAX Bookmarks")
        self.resize(980, 620)
 
    def open(self):
        fileName = QtGui.QFileDialog.getOpenFileName(self,
                "Open XML File", QtCore.QDir.currentPath(),
                "XML Files (*.xml)")[0]
 
        if not fileName:
            return
 
        self.treeWidget.clear()
 
        handler = XmlHandler(self.treeWidget)
        reader = QtXml.QXmlSimpleReader()
        reader.setContentHandler(handler)
        reader.setErrorHandler(handler)
 
        file = QtCore.QFile(fileName)
        if not file.open(QtCore.QFile.ReadOnly | QtCore.QFile.Text):
            QtGui.QMessageBox.warning(self, "GIS UJKH",
                    "Cannot read file %s:\n%s." % (fileName, file.errorString()))
            return
 
        xmlInputSource = QtXml.QXmlInputSource(file)
        if reader.parse(xmlInputSource):
            self.statusBar().showMessage("File zagruzhen", 2000)
 
    def saveAs(self):
        fileName = QtGui.QFileDialog.getSaveFileName(self,
                "Save Bookmark File", QtCore.QDir.currentPath(),
                "XML Files (*.xbel *.xml)")[0]
 
        if not fileName:
            return
 
        file = QtCore.QFile(fileName)
        if not file.open(QtCore.QFile.WriteOnly | QtCore.QFile.Text):
            QtGui.QMessageBox.warning(self, "SAX Bookmarks",
                    "Cannot write file %s:\n%s." % (fileName, file.errorString()))
            return
 
        generator = XmlGenerator(self.treeWidget)
        if generator.write(file):
            self.statusBar().showMessage("File saved", 2000)
 
    def about(self):
         QtGui.QMessageBox.about(self, "About SAX Bookmarks",
                "The <b>SAX Bookmarks</b> example demonstrates how to use "
                "Qt's SAX classes to read XML documents and how to generate "
                "XML by hand.")
 
    def createActions(self):
        self.openAct = QtGui.QAction("&Open...", self, shortcut="Ctrl+O",
                triggered=self.open)
 
        self.saveAsAct = QtGui.QAction("&Save As...", self, shortcut="Ctrl+S",
                triggered=self.saveAs)
 
        self.exitAct = QtGui.QAction("E&xit", self, shortcut="Ctrl+Q",
                triggered=self.close)
 
        self.aboutAct = QtGui.QAction("&About", self, triggered=self.about)
 
        self.aboutQtAct = QtGui.QAction("About &Qt", self,
                triggered=QtGui.qApp.aboutQt)
 
    def createMenus(self):
        self.fileMenu = self.menuBar().addMenu("&File")
        self.fileMenu.addAction(self.openAct)
        self.fileMenu.addAction(self.saveAsAct)
        self.fileMenu.addAction(self.exitAct)
 
        self.menuBar().addSeparator()
 
        self.helpMenu = self.menuBar().addMenu("&Help")
        self.helpMenu.addAction(self.aboutAct)
        self.helpMenu.addAction(self.aboutQtAct)
 
 
if __name__ == "__main__":
 
    import sys
 
    app = QtGui.QApplication(sys.argv)
    mainWin = MainWindow()
    mainWin.show()
    mainWin.open()
    sys.exit(app.exec_())


И собственно сам файл XML
Кликните здесь для просмотра всего текста
XML
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
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE xml>
<xml version="1.0">
    <folder folded="no">
        <title>Метаданные</title>
        
            <bookmark href="http://partners.trolltech.com/partners/training.html">
                <title>Год расчетного периода</title>
                <value>2014</value>
            </bookmark>
            <bookmark href="http://partners.trolltech.com/partners/service.html">
                <title>Месяц расчетного периода</title>
                <value>02</value>
            </bookmark>
            <bookmark href="http://partners.trolltech.com/partners/tech.html">
                <title>ИНН поставщика информации</title>
            </bookmark>
            <bookmark href="http://partners.trolltech.com/partners/resellers.html">
                <title>КПП поставщика информации</title>
            </bookmark>
            <bookmark href="http://partners.trolltech.com/partners/resellers.html">
                <title>ОГРН поставщика информации</title>
            </bookmark>
            <bookmark href="http://partners.trolltech.com/partners/resellers.html">
                <title>КПП поставщика информации</title>
            </bookmark>
            <bookmark href="http://partners.trolltech.com/partners/resellers.html">
                <title>Код дома</title>
            </bookmark>
            <bookmark href="http://partners.trolltech.com/partners/resellers.html">
                <title>Код типа документа</title>
            </bookmark>
            <bookmark href="http://partners.trolltech.com/partners/resellers.html">
                <title>Версия формата</title>
            </bookmark>
 
    </folder>
    <folder folded="no">
        <title>Электронный паспрорт многоквартирного дома</title>
        <bookmark href="http://www.dictionary.com/">
            <title>Dictionary.com</title>
        </bookmark>
        <bookmark href="http://www.m-w.com/">
            <title>Merriam-Webster Online</title>
        </bookmark>
        <bookmark href="http://dictionary.cambridge.org/">
            <title>Cambridge Dictionaries Online</title>
        </bookmark>
        <bookmark href="http://www.onelook.com/">
            <title>OneLook Dictionary Search</title>
        </bookmark>
        <separator/>
        <bookmark href="www.iee.et.tu-dresden.de/">
            <title>The New English-German Dictionary</title>
        </bookmark>
        <bookmark href="http://dict.tu-chemnitz.de/">
            <title>TU Chemnitz German-English Dictionary</title>
        </bookmark>
        <separator/>
        <bookmark href="http://atilf.atilf.fr/tlf.htm">
            <title>Trésor de la Langue Française informatisé</title>
        </bookmark>
        <bookmark href="http://dictionnaires.atilf.fr/dictionnaires/ACADEMIE/">
            <title>Dictionnaire de l'Académie Française</title>
        </bookmark>
        <bookmark href="http://elsap1.unicaen.fr/cgi-bin/cherches.cgi">
            <title>Dictionnaire des synonymes</title>
        </bookmark>
    </folder>
</xml>


Подскажите пожалуйста как сделать так, чтоб можно было добавить какой нить тег в XML например <value></value> и вносить в него изменения через интерфейс программы.

В питон я слаб..
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.02.2014, 16:29
Ответы с готовыми решениями:

Быдлокод
Встречал такое определение. Прошу привести примеры быдлокода и как то же самое правильно пишется.

Как допилить асинхронную функцию?
Как можно правильно допилить асинхронную функцию? и можно еще ресурсы с тренажеркой чтобы изучить asyncio более понятливее для новичка ...

Исправьте мой быдлокод
&lt;? $genurl1 = file_get_contents(&quot;http://localhost/generator/indexgen.php&quot;, &quot;r&quot;); $genurl2 =...

1
 Аватар для ilnurgi
141 / 141 / 38
Регистрация: 20.02.2012
Сообщений: 597
21.02.2014, 07:30
ну править соответственно код.

в код не вникал. тут куты нужны. а у меня их нет.
не думаю что все обойдется правкой одной строчки.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.02.2014, 07:30
Помогаю со студенческими работами здесь

3 числа по возростанию (элегантное решение vs быдлокод)
Вот задача)) Write a program that prompts the user to enter three integer values, and then outputs the values in numerical sequence...

Имеется неделаный быдлокод, нужно слегка подправить.
Здравствуйте! Занимаюсь Prolog'ом второй вечер. Разбираюсь по чужим исходникам, т.к. времени читать книгу нет. Вот заступорился - не знаю...

Быдлокод для использования ENTER_FRAME. Как улучшить код?
Добрый день. Пытался реализовать следующее: на экране есть 2 кнопки - вверх и вниз. При нажатии кнопки вниз сверху опускается...

Какие ошибки программиста вам не нравятся больше всего (костыли, быдлокод)?
Довольно филосовская тема: какие ошибки вам не нравятся больше всего? Какие зверские костыли вам приходилось выпиливать (или вносить...

Допилить ЭС
Вообщем я запутался помогите с эс,мне нужно чтобы правила были во внешней бд и была возможность добавления,а код такой Domains ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru