django使用踩坑經歷

DRF

使用drf獲取序列化后的id

visitor_serializer = VisitorSaveSerializer(data={…})
if visitor_serializer.is_valid():visitor = visitor_serializer.save() visitor_id = visitor.pk

postgrepsql踩坑

django使用postgrepsql,使用聚合函數如:sum 等,被引用的字段必須是浮點數或者整數,不能是字符串

解析Excel

注:如果xlrd版本不合適可導致出現:Excel xlsx file not supported報錯

原因:xlrd1.2.0之后的版本不支持xlsx格式,支持xls格式

辦法一:

卸載新版本 pip uninstall xlrd

安裝老版本:pip install xlrd=1.2.0 (或者更早版本)

方法二:

將xlrd用到的excel版本格式修改為xls(保險起見,另存為xls格式)

建議:個人更推薦使用第二種方法


filename = request.FILES.get('file') #獲取文件name = filename.nametype_excel = name.split(".")[1]
if type_excel in ['xlsx','xls']: #判斷文件是否#開始解析表格wb = xlrd.open_workbook(filename=None, file_contents=filename.read())table = wb.sheets()[0]nrows = table.nrows  # 行數item_list = []try:for specific in range(2, nrows):  # 從0開始把表頭省略則讀取表頭信息,如果從1開始則直接讀取數據rowValues = table.row_values(specific)  # 一行的數據:list
時間查詢
按照周查詢now_time = datetime.datetime.now()# 距離周日相隔的天數,這里得到int型數值day_num = now_time.isoweekday()# 查周日的日期,現在時間減去相隔天數得出周日的日期week_day = (now_time - datetime.timedelta(days=day_num))# 改格式,將datetime類型轉換為date類型monday = week_day.date()query_order = CrmOrder.objects.filter(order_time__range=(monday,now_time))
setting配置
DATA_UPLOAD_MAX_MEMORY_SIZE = 10485760  #數據上傳最大內存大小,默認2.5mb,這里設置成最大10mb
apscheduler定時任務

#注意:定時任務執行的函數需要寫入路由

根據某個時間去創造定時任務

INSTALLED_APPS =[
'django_apscheduler'
]from apscheduler.schedulers.background import BackgroundScheduler
from django_apscheduler.jobstores import DjangoJobStore, register_job, register_events# 實例化調度器
scheduler = BackgroundScheduler()
scheduler.add_jobstore(DjangoJobStore(),"default")#根據重啟時間創建定時任務 到時間發送消息給申請人詢問是否要重啟項目
message_prompt:需要執行的函數 其他參數:年月日時分秒scheduler.add_job(message_prompt, "cron", year=recovery_time.year, month=recovery_time.month,day=recovery_time.day,hour=recovery_time.hour, minute=recovery_time.minute, kwargs={'id':info_poj.id},coalesce=False)

指定時間去執行函數

# 實例化調度器
scheduler = BackgroundScheduler()
# 調度器使用crm_order_add
seconds定時多長時間執行 秒單位
scheduler.add_job(crm_order_add, "interval", seconds=1800, args=['requeat'])  # 半小時執行一次接口
# 監控任務——注冊定時任務
register_events(scheduler)
# 調度器開始運行
scheduler.start()
獲取url.py的name
  current_url = request.resolver_match.url_name
中間件
創建mymiddleware文件夾,創建自己的中間件py
如:讓某個文件夾訪問需要tokenfrom django.http import HttpResponseRedirect, HttpResponse
from django.utils.deprecation import MiddlewareMixin# 設置路由需要驗證的名單
from center.models import Users# whiteUrls = ['media']
#
# class UserAuthMiddleWare(MiddlewareMixin):
#     #訪問路由需要token驗證
#     def process_request(self, request):
#         print(request.path)
#         pat = request.path #訪問路徑
#
#         if pat.split('/')[1] in whiteUrls:
#             token = request.META['HTTP_AUTHORIZATION'] if 'HTTP_AUTHORIZATION' in request.META else None
#             try:
#
#                 userinfo = Users.objects.filter(token=token).first()
#             except Exception as e:
#                 return HttpResponse("PleaseStayAway!")
#             if userinfo is None:
#                 return HttpResponse("PleaseStayAway!")在setting的MIDDLEWARE中導入
MIDDLEWARE = ["mymiddleware.中間件名稱.UserAuthMiddleWare"
]
即可
分頁工具
#工具函數
from django.core.paginator import Paginator, PageNotAnInteger, EmptyPagedef paging_component(reports,pagesize,num_p):""":param reports: 對象數據:param pagesize: 一頁顯示多少個。默認3個:param num_p: 第幾頁:return: 分頁后的對象數據"""paginator = Paginator(reports, pagesize)count = paginator.count  # 需要分類數據的對象總數num_pages = paginator.num_pages  # 需要分類數據的對象總數try:reports = paginator.page(int(num_p))except PageNotAnInteger:reports = paginator.page(number=1)except EmptyPage:reports = paginator.page(1)# print(reports)return {"reports":reports,"count":count,"num_pages":num_pages}#使用方法
pagesize = request.GET.get('pagesize', 10) #pagesize 一頁顯示多少個。默認3個
page = request.GET.get('page', 1)  # 以page為鍵得到默認的頁面1reports:queryset對象列
reports = paging_component(reports,pagesize,page)
reports['reports'].object_list #獲取分頁后的數據

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/66624.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/66624.shtml
英文地址,請注明出處:http://en.pswp.cn/web/66624.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

ASP.NET Core中 JWT 實現無感刷新Token

在 Web 應用開發中,用戶登錄狀態的管理至關重要。為了避免用戶頻繁遇到登錄過期的問題,我們可以通過實現 JWT(JSON Web Token)刷新機制來提升用戶體驗 推薦: 使用 Refresh Token(雙 Token 機制) 1. 生成和…

將 AzureBlob 的日志通過 Azure Event Hubs 發給 Elasticsearch(3.純python的實惠版)

前情: 將 AzureBlob 的日志通過 Azure Event Hubs 發給 Elasticsearch(1.標準版)-CSDN博客 將 AzureBlob 的日志通過 Azure Event Hubs 發給 Elasticsearch(2.換掉付費的Event Hubs)-CSDN博客 python腳本實現 厲害的…

python學opencv|讀取圖像(四十)掩模:三通道圖像的局部覆蓋

【1】引言 前序學習了使用numpy創建單通道的灰色圖像,并對灰色圖像的局部進行了顏色更改,相關鏈接為: python學opencv|讀取圖像(九)用numpy創建黑白相間灰度圖_numpy生成全黑圖片-CSDN博客 之后又學習了使用numpy創…

【全面解析】深入解析 TCP/IP 協議:網絡通信的基石

深入解析 TCP/IP 協議:網絡通信的基石 導語 你是否曾好奇,現代互聯網是如何實現全球設備之間的高速、穩定和可靠通信的?無論是瀏覽網頁、發送電子郵件,還是進行視頻通話,背后都離不開 TCP/IP 協議 的支撐。作為互聯網…

全面解析 Java 流程控制語句

Java學習資料 Java學習資料 Java學習資料 在 Java 編程中,流程控制語句是構建程序邏輯的關鍵部分,它決定了程序的執行順序和走向。通過合理運用這些語句,開發者能夠實現各種復雜的業務邏輯,讓程序更加靈活和智能。 順序結構 順…

Linux系統常用指令

查找文件 find / -name "<文件名>" 2>/dev/null //遍歷系統查找指定文件名文件ls -l | grep "<文件名>" //列出當前目錄下有關文件名的文件find -name sw_sfp_alarm_cfg.xml //查找文件名對應路徑 切換目錄 編輯文件 vi <文件…

【Unity】ScrollViewContent適配問題(Contentsizefilter不刷新、ContentSizeFilter失效問題)

最近做了一個項目&#xff0c;菜單欄讀取數據后自動生成&#xff0c;結果用到了雙重布局 父物體 嘗試了很多方式&#xff0c;也看過很多大佬的文章&#xff0c;后來自己琢磨了一下&#xff0c;當子物體組件自動生成之后&#xff0c;使用以下以下代碼效果會好一些&#xff1a; …

AI輔助醫學統計分析APP

AI輔助醫學統計分析APP 醫學統計分析的困難點在于開始階段分析的規劃和得出分析結果之后分析結果的解釋&#xff0c;前者之所以困難是因為分析方法繁多又有不同的使用條件&#xff0c;后者則是因為結果中術語較多&#xff0c;且各種分析方法術語又有不同&#xff0c;非統計專業…

[STM32 HAL庫]串口中斷編程思路

一、前言 最近在準備藍橋杯比賽&#xff08;嵌入式賽道&#xff09;&#xff0c;研究了以下串口空閑中斷DMA接收不定長的數據&#xff0c;感覺這個方法的接收效率很高&#xff0c;十分好用。方法配置都成功了&#xff0c;但是有一個點需要進行考慮&#xff0c;就是一般我們需要…

淺談Java之AJAX

一、基本介紹 在Java開發中&#xff0c;AJAX&#xff08;Asynchronous JavaScript and XML&#xff09;是一種用于創建動態網頁的技術&#xff0c;它允許網頁在不重新加載整個頁面的情況下與服務器進行交互。 二、關鍵點和示例 1. AJAX的基本原理 AJAX通過JavaScript的XMLHtt…

AutoSar架構學習筆記

1.AUTOSAR&#xff08;Automotive Open System Architecture&#xff0c;汽車開放系統架構&#xff09;是一個針對汽車行業的軟件架構標準&#xff0c;旨在提升汽車電子系統的模塊化、可擴展性、可重用性和互操作性。AUTOSAR的目標是為汽車電子控制單元&#xff08;ECU&#xf…

算法競賽之差分進階——等差數列差分 python

目錄 前置知識進入正題實戰演練 前置知識 給定區間 [ l, r ]&#xff0c;讓我們把數組中的[ l, r ] 區間中的每一個數加上c,即 a[ l ] c , a[ l 1 ] c , a[ l 2] c , a[ r ] c; 怎么做&#xff1f;很簡單&#xff0c;差分一下即可 還不會的小伙伴點此進入學習 進入正題 …

TDengine 做 Apache SuperSet 數據源

?Apache Superset? 是一個現代的企業級商業智能&#xff08;BI&#xff09;Web 應用程序&#xff0c;主要用于數據探索和可視化。它由 Apache 軟件基金會支持&#xff0c;是一個開源項目&#xff0c;它擁有活躍的社區和豐富的生態系統。Apache Superset 提供了直觀的用戶界面…

金融場景 PB 級大規模日志平臺:中信銀行信用卡中心從 Elasticsearch 到 Apache Doris 的先進實踐

導讀&#xff1a;中信銀行信用卡中心每日新增日志數據 140 億條&#xff08;80TB&#xff09;&#xff0c;全量歸檔日志量超 40PB&#xff0c;早期基于 Elasticsearch 構建的日志云平臺&#xff0c;面臨存儲成本高、實時寫入性能差、文本檢索慢以及日志分析能力不足等問題。因此…

虛幻商城 Fab 免費資產自動化入庫

文章目錄 一、背景二、實現效果展示三、實現自動化入庫一、背景 上一次寫了個這篇文章 虛幻商城 Quixel 免費資產一鍵入庫,根據這個構想,便決定將范圍擴大,使 Fab 商城的所有的免費資產自動化入庫,是所有!所有! 上一篇文章是根據下圖這部分資產一鍵入庫: 而這篇文章則…

游戲為什么失敗?回顧某平庸游戲

1、上周玩了一個老鼠為主角的游戲&#xff0c;某平臺喜1送的&#xff0c; 下載了很久而一直沒空玩&#xff0c;大約1G&#xff0c;為了清硬盤空間而玩。 也是為了拔掉心中的一根刺&#xff0c;下載了而老是不玩總感覺不舒服。 2、老鼠造型比較寫實&#xff0c;看上去就有些討…

親測有效!如何快速實現 PostgreSQL 數據遷移到 時序數據庫TDengine

小T導讀&#xff1a;本篇文章是“2024&#xff0c;我想和 TDengine 談談”征文活動的優秀投稿之一&#xff0c;作者從數據庫運維的角度出發&#xff0c;分享了利用 TDengine Cloud 提供的遷移工具&#xff0c;從 PostgreSQL 數據庫到 TDengine 進行數據遷移的完整實踐過程。文章…

C#,入門教程(01)—— Visual Studio 2022 免費安裝的詳細圖文與動畫教程

通過本課程的學習&#xff0c;你可以掌握C#編程的重點&#xff0c;享受編程的樂趣。 在本課程之前&#xff0c;你無需具備任何C#的基礎知識&#xff0c;只要能操作電腦即可。 不過&#xff0c;希望你的數學不是體育老師教的。好的程序是數理化的實現與模擬。沒有較好的數學基礎…

Linux探秘坊-------3.開發工具詳解(2)

1.動靜態庫和動靜態鏈接&#xff08;操作&#xff09; 靜態庫是指編譯鏈接時,把庫?件的代碼全部加?到可執??件中,因此?成的?件 ?較?,但在運?時也就不再需要庫?件了。其后綴名?般為“.a” 動態庫與之相反,在編譯鏈接時并 沒有把庫?件的代碼加?到可執??件中 ,?…

電腦開機出現Bitlock怎么辦

目錄 1.前言 2.產生原因&#xff1a; 1.系統異常關機 2.系統更新錯誤 3.硬件更換 4.CMOS電池問題 5.出廠設置 6.意外情況 3.解鎖步驟&#xff1a; 3.1&#xff1a;記住密鑰ID&#xff08;前6位&#xff09; 3.2&#xff1a;打開aka.ms/myrecoverykey網址 3.3&#…