Django传递dataframe对象到前端网页

在django前端页面上展示的数据,还是使用django模板自带的语法

方式1 不推荐使用 直接使用 【df.to_html(index=False)】

        使用to_html他会生成一个最基本的表格没有任何的样式,一点都不好看,如果有需要的话可以自行修改表格的样式,但博主觉得这样的方式太麻烦,

        后端

df = pd.DataFrame({'Name': ['John', 'Alice', 'Smith'],
                           'Age': [30, 25, 35],
                           'City': ['New York', 'London', 'Paris']})

# 将DataFrame转换为HTML字符串
table_html = df.to_html(index=False)
    
# 将表格数据和其他数据打包成上下文对象
content= {
    'table_html': table_html
    }
return render(request, '自己的前端网页', content)

        前端

<!DOCTYPE html>
<html>
<head>
</head>
<body>
    <table>
        {{ table_html | safe }}
    </table>
    <!-- 其他页面内容 -->
</body>
</html>

         效果

        

方式2  推荐使用 将df转为字典放到特定的表格下

        这个表格是博主已经写好<table>有一定的样式了,这个方式就是将每一行数据给放到表格里面,相当于只是传递了数值。

        下面的django模板语法能够动态的更新标题行和数据,数据表格有变动不需要修改前端模板

         后端

df = pd.DataFrame({'Name': ['John', 'Alice', 'Smith'],
                           'Age': [30, 25, 35],
                           'City': ['New York', 'London', 'Paris']})
table_data = df.to_dict('records')
table_headers = df.columns.tolist()
content = {
    'table_headers':table_headers,
    'table_data': table_data
}
return render(request, '自己的前端网页', content)

        前端

<!DOCTYPE html>
<html>
<head>
</head>
<body>
    <div class="table-responsive">
        <div id="example_wrapper" class="dataTables_wrapper">
            <table id="example" class="display table dataTable" role="grid"
                               aria-describedby="example_info">
                <thead>
                    <tr>
                        {% for header in table_headers %}
                            <th>{{ header }}</th>
                        {% endfor %}
                        </tr>
                </thead>
                <tbody>
                    {% for row in table_data %}
                        <tr>
                            {% for value in row.values %}
                                 <td>{{ value }}</td>
                            {% endfor %}
                        </tr>
                    {% endfor %}
                 </tbody>
            </table>
        </div>
    </div>
    <!-- 其他页面内容 -->
</body>
</html>

         效果

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将图片传到前端,首先需要在Django中定义一个视图函数来处理图片的请求。以下是一个简单的例子: ```python from django.http import HttpResponse, JsonResponse from django.shortcuts import render from django.conf import settings import os def image(request, image_name): image_path = os.path.join(settings.MEDIA_ROOT, image_name) if os.path.exists(image_path): with open(image_path, 'rb') as f: return HttpResponse(f.read(), content_type='image/jpeg') else: return JsonResponse({'success': False, 'message': 'Image not found'}) ``` 在这个视图函数中,我们通过image_name参数获取图片的名字,然后将其转换为图片的绝对路径。如果图片存在,我们就打开它并返回一个HttpResponse对象,将图片的二进制数据作为响应内容,同时将content_type设置为'image/jpeg'。如果图片不存在,我们就返回一个JsonResponse对象,表明图片未找到。 接下来,在urls.py文件中定义一个URL模式来映射到这个视图函数: ```python from django.urls import path from . import views urlpatterns = [ path('image/<str:image_name>/', views.image, name='image'), ] ``` 最后,在模板中使用如下代码来显示图片: ```html <img src="{% url 'image' image_name %}" alt="Image"> ``` 这里的image_name是你要显示的图片的名字,可以从数据库或其他源中获取。在模板中使用Django的url模板标签来生成图片的URL,然后将其赋值给img标签的src属性即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值