django解析用户上传的excel文件

Roy
有些时候我们会有这种需求:用户上传一个格式固定excel表格到网站上,然后程序负债解析内容并进行处理。 举一个简单的栗子,比如我们有这样一个HTML: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> </head> <body> <p>上传EXCEL表格</p> <form class="" action="" method="post" enctype="multipart/form-data" > {% csrf_token %} <input type="file" name="excel"> <input type="submit" value="上传"> </form> </body> </html> forms.

使用python模拟POST请求提交图片

Roy

使用requests来模拟HTTP请求本来是一件非常轻松的事情,比如上传图片来说,简单的几行代码即可:

import requests
files = {'attachment_file': ('1.png', open('1.png', 'rb'), 'image/png', {})}
values = {'next':"http://www.xxxx.com/xxxx"}
r = requests.post('http://www.xxxx.com/upload', files=files, data=values) # 成功

r = requests.post('http://www.xxxx.com/upload', files=files, data=values) # 失败

r = requests.post('http://www.xxxx.com/upload', files=files, data=values) # 失败

r = requests.post('http://www.xxxx.com/upload', files=files, data=values) # 失败

r = requests.post('http://www.xxxx.com/upload', files=files, data=values) # 失败

...

不过我今天在调试一个django程序的时候却遇到了大坑————为了偷懒,我直接在ipython中执行了上述代码,第一次提交的时候一切正常,但第二次之后提交就怎么也通过不了django的form验证。

django-auth-ldap中文文档

Roy
最近在学习如何结合Django和LDAP服务进行用户认证,关于在Centos7上LDAP的服务器如何搭建可以参考这里。 阅读文档的时候发现网上没有关于django-auth-ldap的完整翻译,所以把我阅读文档时的理解记录下来,如有错误还请指正。 django-auth-ldap中文文档

在MySQL中存储树状结构

Roy

原文地址,原文中Hierarchical Data直译为 分层结构,这里我翻译成 树状结构

补充资源:

  1. https://django-mptt.github.io/django-mptt/ ,如果你也使用python和django,这个是现成的APP。

另外,个人觉得这种方法对于搜索的效率提升最大,而相应的新增、删除等操作则会变慢,个人猜测未经测试。

个人总结的核心:如果一个节点A是节点B的子节点,那么A的左值一定大于B的左值,A的右值一定小于B的右值。或者说,A的左值一定在B的左值和右值之间。

Flask+HTML5实现服务器推送事件

Roy

服务器推送事件(server-sent events,SSE)是一种除websocket、ajax简单轮寻外另一种实现服务器数据主动推送数据到浏览器的方式。

这里,举一个的例子来说明如何使用基于pyhon的服务端来实现,为了简单我使用flask框架来实现。关键点有2个:

  1. HTTP响应头中包含content-type:text/event-stream
  2. 流响应