python - 替换 SQL 查询中的值

标签 python mysql sql django replace

我创建了一个应用程序,按照以下代码从某些数据库项目打印试算表。

当前打印结果如下例所示:

enter image description here

我如何才能用空格替换表中的“0”,以便其显示如下: enter image description here

View .py

def Kyletrb(request):
    all =  'SELECT Master_Sub_Account , cAccountTypeDescription , Debit , Credit FROM [Kyle].[dbo].[PostGL] '\
                    'Inner JOIN [Kyle].[dbo].[Accounts] '\
                    'on Accounts.AccountLink = PostGL.AccountLink '\
                    'Inner JOIN [Kyle].[dbo].[_etblGLAccountTypes] as AccountTypes '\
                    'on Accounts.iAccountType = AccountTypes.idGLAccountType'

    cursor = cnxn.cursor();
    cursor.execute(all);
    xAll = cursor.fetchall()
    cursor.close()
    xAll_l = []
    for row in xAll:
        rdict = {}
        rdict["Description"] = row[0]
        rdict["Account"] = row[1]
        rdict["Credit"] = row[2]
        rdict["Debit"] = row[3]
        xAll_l.append(rdict)

    creditTotal = ' Select ROUND(SUM(Credit) , 2) FROM [Kyle].[dbo].[PostGL] WHERE Credit <> 0.0'
    cursor = cnxn.cursor();
    cursor.execute(creditTotal);
    xCreditTotal = cursor.fetchone()

    debitTotal = ' Select ROUND(SUM(Debit) , 2) FROM [Kyle].[dbo].[PostGL] WHERE Debit <> 0.0'
    cursor = cnxn.cursor();
    cursor.execute(debitTotal);
    xDebitTotal = cursor.fetchone()

    return render(request , 'main/Kyletrb.html' , {"xAlls":xAll_l , 'xCreditTotal':xCreditTotal , 'xDebitTotal':xDebitTotal})

HTML:

<link href="https://cdn.jsdelivr.net/npm/<a href="https://stackoverflow.com/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="60020f0f14131412011020554e504e50" rel="noreferrer noopener nofollow">[email protected]</a>/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-wEmeIV1mKuiNpC+IOBjI7aAzPcEZeedi5yW5f2yOq55WWLwNGmvvx4Um1vskeMj0" crossorigin="anonymous">
{% extends "main/base.html"%}

{% block content%}
<h1 class = 'center'>Kyle Database Trial Balance</h1>
<br>
<style>
   .img-container {

     width: 150px;
     height: 100px;
   }
 </style>
<style>
  .center{
    text-align: center;
  }
</style>
<style>
  .table-container{
      border-bottom: 1px solid #ddd;
      border-top: 1px solid #ddd;
      padding-left: 350px;
  }
</style>

</div>
<br>
<br>

<div class="table-container">
<table style="width: 100%">
  <th >Account</th>
  <th>Description</th>
  <th>Debit</th>
  <th>Credit</th>
  {% for xAll in xAlls %}
    <tr>
      <td>{{ xAll.Description }}</td>
      <td>{{ xAll.Account }}</td>
      <td>{{ xAll.Debit }}</td>
      <td>{{ xAll.Credit }}</td>
    </tr>
  <tr>
  {% endfor %}
  <td> <b>Totals</b> </td>
  <td> </td>
  {% for xDebitTotal in xDebitTotal %}
  <td><b>R {{ xDebitTotal }}</b></td>
  {% endfor %}

  {% for xCreditTotal in xCreditTotal %}
  <td><b>R {{ xCreditTotal }}</b></td>
  {% endfor %}

  </tr>
</table>
</div>
<br>
<br>
<br>
<br><br><br>

<div class="img-container">
<p>Prepared By :</p>
<img src="" alt="GMA" >
</div>


<br>
<br>
<div class="">
<a href="{% url 'printToPdf' %}" class="btn btn-primary">Print To PDF</a>
</div>
{% endblock %}

我怎样才能做到这一点? 如果有人有示例/一些文档,请分享。

最佳答案

要以最简单的方式实现此结果,您可以在模板中实现 if else。

举个例子

借记卡

<td>
    {%if xAll.Debit > 0%}
    {{xAll.Debit}}
    {%endif%}
</td>

信用

<td>
    {%if xAll.Credit > 0%}
    {{xAll.Credit}}
    {%endif%}
</td>

如果您关心代码的外观,那么您可以创建自定义小部件。

关于python - 替换 SQL 查询中的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69030649/

相关文章:

python - 仅从公钥破解长 RSA key

python - 带有类方法的 Cython 回调

mysql - SQL 查询 - 按日期排序但也按组排序

c# - c#中的参数无效异常

mysql - SQL 子查询连接

javascript - 如何修复 Django 中的 "object() takes no parameters"错误

mysql - 使用 Access 和 ODBC 驱动程序从 MySQL 获取最后一个自动增量

mysql - Openfire 自定义数据库登录

sql - 如何从基于多个表的 Oracle 结果集中删除重复项

python - 加快 Python 循环追加速度