0

私のアプリケーションは順調に進んでおり、私が助けを求めたすべての問題を抱えている. 私はよくグーグルで検索し、ReportLab Toolkit、reStructuredText などを見つけましたが、それは私が探しているものではありません。

これが私のコードです:(貼り付けのためにインデントが少しずれている可能性があります)

def preparePrint(self):
 caseNumber = (str(self.ui.linecaseNumber.text()).upper())
 if caseNumber:
  with con:
   cur = con.cursor()
   cur.execute('SELECT notes FROM cases WHERE caseNumber =?',[caseNumber])
   tempnotes=str(cur.fetchone())
   cur.execute('SELECT name FROM cases WHERE caseNumber =?',[caseNumber])
   tempname=str(cur.fetchone())
   cur.execute('SELECT date FROM cases WHERE caseNumber =?',[caseNumber])
   tempdate = str(cur.fetchone()) #fetch 3 values from SQLite database

    #get rid of "tuple marks"
   tempname = (str(tempname.replace('(','').replace(')','').replace(',','').replace("'","")))
   tempnotes = (str(tempnotes.replace('(','').replace(')','').replace(',','').replace("'",""))) 
   tempdate=(str(tempdate.replace('(','').replace(')','').replace(',','').replace("'",""))) 

    #join them in one string. Notice the \n
   finalText = (str("NAME: %s\nDATE: %s\nNOTES: %s" %(tempname,tempdate,tempnotes))) 

#put the joined string into one QTextEdit, while preserving HTML properties (bold mostly).
   self.ui.textPrint.setHtml(str(finalText.replace('(','').replace(')','').replace(',','').replace("'","").replace('\\n','\r')))  

この関数の後に、改行文字以外で動作する PDF を作成する関数があります。finalTextをコンソールに出力すると、希望どおりに表示されます。QTextEditではそのようには見えません:(

コンソール出力:

Name: Some Name
Date: 14.07.2012
Notes: Some notes go here

QTextEdit と PDF 出力:

Name: Some Name Date: 14.07.2012 Notes: Some notes go here
4

2 に答える 2

1

このコードは非常に多くの場所で間違っています...
多くの改善と適切な行の長さでコードを修正しました:

def preparePrint(self):
    caseNumber = str(self.ui.linecaseNumber.text()).upper()
    if caseNumber:
        with con:
            cur = con.cursor()
            # fetch 3 values from SQLite database
            cur.execute('SELECT notes FROM cases WHERE caseNumber = ?',
                        caseNumber)
            tempnotes = cur.fetchone()[0]
            # if you have multiple columns, use:
            # tempnotes = ''.join(cur.fetchone())
            cur.execute('SELECT name FROM cases WHERE caseNumber = ?',
                        caseNumber)
            tempname = cur.fetchone()[0]
            cur.execute('SELECT date FROM cases WHERE caseNumber = ?',
                        caseNumber)
            tempdate = cur.fetchone()[0]

        # no need to 'get rid of "tuple marks"',
        # because they aren't there now

        # join them in one string. Notice the \n
        finalText = ("NAME: %s\nDATE: %s\nNOTES: %s"
                     % (tempname, tempdate, tempnotes))

        # put the joined string into one QTextEdit, 
        # while preserving HTML properties (bold mostly).

        # again, no need to 'get rid of "tuple marks"'
        self.ui.textPrint.setHtml(finaltext)

これにより、改行のあるテキストが作成されます。そうでない場合は、\r\n代わりに in finaltextを使用してみてください\n。それでもうまくいかない場合は、何かおかしなことが起こっていますが、少なくともより良いコードが得られます。

于 2012-07-14T12:20:24.437 に答える
0

私はそれを割った!:D QTextEdit は HTML を受け入れるため、 < br > タグは改行を作成します。元の投稿とは異なるコードは次のとおりです。

finalText = (str("NAME: %s%sDATE: %s%sNOTES: %s%s" %(tempname,'<br>',tempdate,'<br>',tempnotes,'<br>')))
self.ui.textPrint.setHtml(str(finalText).replace('\\n','\r'))
于 2012-07-14T12:36:24.010 に答える