更多课程 选择中心

Python培训
美国上市教育机构

400-111-8989

Python培训

Python实战【第五节】搜一下

  • 发布:Python培训
  • 来源:Crossin的编程教室
  • 时间:2019-03-22 15:20

欢迎大家来到Python自学教程实战篇,上一讲我们已经能让这个电影网站看起来更像一个网站了,但是我们做的是一个电影网站,内容型的网站,要是用户不能再站内搜索自己喜欢的影片信息,那得多尴尬呀,所以我们今天就来试着实现一下这个搜索功能,一起来看看:

Python实战【第五节】搜一下

我们的网站怎样才能实现搜索功能呢?HTML 里有一个 form 标签,它的作用是创建一个表单,用来提交一些数据。诸如搜索、登录、评论等操作,都可以通过 form 标签来解决。前面说过,我们直接在流量器里访问一个 url 地址是向服务器发送了一个 GET 请求。而用 form,就可以选择使用 POST 请求,从而更方便更安全地传递数据。

这件事情的大体思路是,在首页上通过 form 标签增加一个搜索框。当用户输入文字点击搜索后,会向服务器发送一个 POST 请求。服务器端的代码里拿到请求中的文字,在数据库里搜索标题中包含此文字的影片列表,返回给首页模板进行显示。

在首页模板 index.html 中添加搜索框:

<form action="/" method="post">

<input type="text" name="title" />

<input type="submit" value="搜索" />

</form>

action 是请求的地址,这里选择向首页请求,method 表示方法是 POST。input 是表单中的元素,type="text" 表示一个文本框,name="title" 在服务器端处理数据时会用到。type="submit" 表示一个提交按钮,value="搜索" 是按钮上显示的文字。

添加完之后刷新页面,可以看到已经有了一个搜索框。不过此时输入内容并点击“搜索”后,页面会显示 None。这是因为服务器端的 index 类中还没有对 POST 请求做相应的处理。所以,在 code.py 里,index 类中的 GET 方法下,增加一个类似的 POST 方法:

def POST(self):

data = web.input()

condition = r'title like "%' + data.title + r'%"'

movies = db.select('movie', where=condition)

return render.index(movies)

web.input() 拿到的是表单传入的数据,data.title 就是用户输入的文本。与 GET 方法中获取数据库中所有影片不同,这里额外增加一项搜索条件:

title like "%搜索内容%"

这里用r''是为了防止 python 默认对于字符串中 % 的转义。

like 是 SQL 的语法,% 表示匹配 0 到任意多个字符。这里对应完整的 SQL 查询语句是:

select * from movie where title like "%搜索内容%";

执行效果是查询出所有标题中包含(搜索内容)的影片数据。

此时再点击搜索,便可看见,首页上的影片列表只会列出符合搜索条件的影片标题。在之后数据量增加的情况下,这个小小的功能将会大有用处。

恭喜您在Python自学的道路上又坚持了一天,我们目前学习的知识比之前的要复杂一些,但是也比之前的有趣多了,所以希望大家跟上我们的步伐,继续加油!

免责声明:内容和图片源自网络,版权归原作者所有,如有侵犯您的原创版权请告知,我们将尽快删除相关内容。

预约申请免费试听课

填写下面表单即可预约申请免费试听!怕钱不够?可就业挣钱后再付学费! 怕学不会?助教全程陪读,随时解惑!担心就业?一地学习,可全国推荐就业!

上一篇:Python实战【第四节】更多的页面
下一篇:Python实战【第六节】拿来主义

【Git第八节】移除文件

【Python实战】四行Python代码就能知道你那的天气,你敢信?

Python实战【用Python写游戏第十三节】exe打包

Python实战【用Python写游戏第十二节】屡败屡战

选择城市和中心
黑龙江省

吉林省

河北省

湖南省

贵州省

云南省

广西省

海南省