前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >七日Python之路--第八天

七日Python之路--第八天

作者头像
lpe234
发布2020-07-28 15:06:18
4080
发布2020-07-28 15:06:18
举报
文章被收录于专栏:若是烟花若是烟花

说实话七天学完Python,确实有些难度。O(∩_∩)O哈哈~ 七天只是约数。

今天学的东西比较杂乱,看了些Django的model和view,早晨还看了一点socket编程方面,刚才还看了些sqlite3的一下东西。下面分开来写下吧。

(一)SQLite3

Ubuntu下面安装

代码语言:javascript
复制
dizzy@dizzy-pc:~$ sudo apt-get install sqlite3

SQLite3使用还是比较简单的,一个数据库文件就能搞定。

打开数据库:

代码语言:javascript
复制
dizzy@dizzy-pc:~/Python/django_project/form_test$ sqlite3 db.sqlite3
SQLite version 3.7.9 2011-11-01 00:52:41
Enter ".help" for instructions
Enter SQL statements terminated with a ";"
sqlite>

然后就可操作当前打开的数据库了:

代码语言:javascript
复制
sqlite> .tables  #查看所有数据库表,相当于MySQL的show tables;
auth_group                  auth_user_user_permissions
auth_group_permissions      blog_user                 
auth_permission             django_admin_log          
auth_user                   django_content_type       
auth_user_groups            django_session

还有一些通用的SQL语句:

代码语言:javascript
复制
sqlite> select * from blog_user;
1|admin|upload/python_fn.vim
sqlite>

sqlite> .schema table_name
#查看表结构

#输入 .help 查看更多帮助 !!!

就说这么多吧。SQLite3在手机等嵌入式中使用的比较多,小巧简单。

(二)Python的socket编程。

需要使用 import socket. socket编程多是C/S架构。

下面简单的例子。

代码语言:javascript
复制
#server.py

#!/usr/bin/python
#coding=utf-8

import socket
#创建socket对象,使用IPV4,TCP协议
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
#将socket绑定到IP地址及端口。tuple元组类型,一个参数
socket.bind(('127.0.0.1',9999))
#设置监听,并设置最大监听数
socket.listen(10)
#等待请求,返回请求者的连接对象和地址元组(IP:PORT)。
conn,addr = socket.accept()
#获取请求者发送的数据
buff = conn.recv(1024)
print buff
代码语言:javascript
复制
#client.py

#!/usr/bin/python
#coding=utf-8

import socket
#创建socket对象
sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
#连接服务器
sock.connect(('127.0.0.1',9999))
#向服务器发送数据
sock.send(str(raw_input('input msg.')))

当然这是很简单的例子,要学习的东西还有很多...... 以后在研究socket.....


--2014年07月28日19:46:38

(三)Django相关
(1)Cookies

在Response.COOKIES。是Python的一个标准字典型。可以将服务器的K-V数据进行保存。

cookie的设置:

代码语言:javascript
复制
def login(req):
    if req.method == 'POST':
        form = UserForm(req.POST)
        if form.is_valid():
            username = form.cleaned_data['username']
            password = form.cleaned_data['password']
            users = User.objects.filter(username__exact=username, password__exact=password)
            if users:
                resp = HttpResponseRedirect('/blog/index/')
                #使用response.set_cookie(key,value,timeout)
                resp.set_cookie('username',username,60*60)
                return resp
            else:
                return HttpResponseRedirect('/blog/login/')
    else:
        form = UserForm()
    return render_to_response('login.html',{'form':form})

cookie的使用与读取:

代码语言:javascript
复制
def index(req):
    #使用request.COOKIES.get(key)获取value的值
    username = req.COOKIES.get('username')
    return render_to_response('index.html',{'username':username})

cookie的删除:

代码语言:javascript
复制
def logout(req):
    resp = HttpResponse('logout')
    #使用response.delete_cookie(key),删除cookie
    resp.delete_cookie('username')
    return resp
(2)session

为了数据的安全,有时需要将一些与用户有关的信息保存到服务器上。request.session

session的创建与使用:

代码语言:javascript
复制
def login(req):
    if req.method == 'POST':
        form = UserForm(req.POST)
        if form.is_valid():
            username = form.cleaned_data['username']
            password = form.cleaned_data['password']
            users = User.objects.filter(username__exact=username, password__exact=password)
            if users:
                resp = HttpResponseRedirect('/blog/index/')
                resp.set_cookie('username',username,60*60)
                #使用 request.session[key]=value 来对session进行赋值
                req.session['username'] = username
                return resp
            else:
                return HttpResponseRedirect('/blog/login/')
    else:
        form = UserForm()
    return render_to_response('login.html',{'form':form})

session的读取:

代码语言:javascript
复制
def index(req):
    #username = req.COOKIES.get('username')
    #使用 request.session.get(key) 来获取value
    username = req.session.get('username')
    return render_to_response('index.html',{'username':username})

session的删除:

代码语言:javascript
复制
def logout(req):
    resp = HttpResponse('logout')
    #resp.delete_cookie('username')
    #直接通过删除命令 del 进行删除。
    del req.session['username']
    return resp
(3)auth

User的使用。

代码语言:javascript
复制
 from django.contrib.auth.models import User

User的创建:

代码语言:javascript
复制
#在Python 交互 shell 中实现。至少需要两个参数:username, password
>>> User.objects.create_user(username='aaa',password='aaa')

劳逸结合才是王道! 可惜还是没有什么困意 。。。。。 Org......

--2014年07月29日01:55:45

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • (一)SQLite3
  • (二)Python的socket编程。
  • (三)Django相关
    • (1)Cookies
      • (2)session
        • (3)auth
        相关产品与服务
        云数据库 MySQL
        腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档