wxPython中文教程 简单入门加实例
wx.Window 是一个基类,许多构件从它继承。包括 wx.Frame 构件。技术上这意味着,我们可以在所有的
* SetToolTip( wx.ToolTip tip ) —— 为窗口添加提示。
* SetSize( wx.Size size ) —— 设置窗口的尺寸。
* SetPosition( wx.Point pos ) —— 设置窗口出现的位置。
* Show( show = True ) —— 显示或隐藏窗口。其中的参数可以为 True 或False。
* Move( wx.Point pos ) —— 将窗口移动到指定位置。
* SetCursor( wx.StockCursor id ) —— 设置窗口的鼠标指针样式。
- import wx
- app = wx.PySimpleApp()
- frame = wx.Frame( None, -1, '' )
- frame.SetToolTip( wx.ToolTip( 'This is a frame' ) )
- frame.SetCursor( wx.StockCursor( wx.CURSOR_MAGNIFIER ) )
- frame.SetPosition( wx.Point( 0, 0 ) )
- frame.SetSize( wx.Size( 300, 250 ) )
- frame.SetTitle( 'simple2.py' )
- frame.Show()
- app.MainLoop()
wx.CURSOR_RIGHT_ARROW
wx.CURSOR_BLANK
wx.CURSOR_BULLSEYE
wx.CURSOR_CHAR
wx.CURSOR_CROSS
wx.CURSOR_HAND
wx.CURSOR_IBEAM
wx.CURSOR_LEFT_BUTTON
wx.CURSOR_MAGNIFIER
wx.CURSOR_MIDDLE_BUTTON
wx.CURSOR_NO_ENTRY
wx.CURSOR_PAINT_BRUSH
wx.CURSOR_PENCIL
wx.CURSOR_POINT_LEFT
wx.CURSOR_POINT_RIGHT
wx.CURSOR_QUESTION_ARROW
wx.CURSOR_RIGHT_BUTTON
wx.CURSOR_SIZENESW
wx.CURSOR_SIZENS
wx.CURSOR_SIZENWSE
wx.CURSOR_SIZEWE
wx.CURSOR_SIZING
wx.CURSOR_SPRAYCAN
wx.CURSOR_WAIT
wx.CURSOR_WATCH
wx.CURSOR_ARROWWAIT
======================================================================
wx.Frame 是一个容器构件。这意味着它可以容纳其它构件。它有如下的构造器:
- import wx
- def main():
- app=wx.PySimpleApp()
- frame=wx.Frame(None,-1,'Icon',wx.DefaultPosition,wx.Size(350,300))
- frame.SetIcon(wx.Icon('Tipi.ico',wx.BITMAP_TYPE_ICO))
- frame.Center()
- frame.Show()
- app.MainLoop()
- if __name__ == '__main__':
- main()
======================================================================
创建一个菜单栏在wxPython中相当简单。我们将讨论给菜单栏添加菜单、为已经存在的菜单添加子菜单。所有菜单都有菜单项组成。菜单项可以是常规项、复选项以及单选项。
edit = wx.Menu()
help = wx.Menu()
file.Append( 102, '&Save', 'Save the document' )
quit.SetBitmap(wx.Image('stock_exit-16.png', wx.BITMAP_TYPE_PNG).ConvertToBitmap())
file.AppendItem(quit)
menubar.Append( edit, '&Edit' )
menubar.Append( help, '&Help' )
- #!/usr/bin/env python
- # FileName: menu1.py
- import wx
- class MyMenu( wx.Frame ):
- def __init__(self,parent,ID,title):
- wx.Frame.__init__(self,parent,-1,title,wx.DefaultPosition,wx.Size(200, 150))
- menubar=wx.MenuBar()
- file=wx.Menu()
- edit=wx.Menu()
- help=wx.Menu()
- file.Append(101,'&Open','Open a new document')
- file.Append(102,'&Save','Save the document')
- file.AppendSeparator()
- quit=wx.MenuItem(file,105,'&Quit\tCtrl+Q','Quit the Application')
- quit.SetBitmap(wx.Image('stock_exit-16.png', wx.BITMAP_TYPE_PNG).ConvertToBitmap())
- file.AppendItem(quit)
- menubar.Append(file,'&File')
- menubar.Append(edit,'&Edit')
- menubar.Append(help,'&Help')
- self.SetMenuBar( menubar )
- class MyApp(wx.App):
- def OnInit(self):
- frame=MyMenu(None,-1,'menu1.py')
- frame.Show(True)
- return True
- app=MyApp(0)
- app.MainLoop()
edit.Append( 202, 'check item2', '', kind=wx.ITEM_CHECK )
* wx.ITEM_CHECK —— 复选
* wx.ITEM_RADIO —— 单选
submenu.Append( 302, 'radio item2', kind=wx.ITEM_RADIO )
submenu.Append( 303, 'radio item3', kind=wx.ITEM_RADIO )
self.Close()
下面的脚本会展示上面说的各种菜单项、子菜单以及一个简单的事件处理。我讨厌程序窗口出现在角落里,所以加上了:
- #!/usr/bin/python
- # FileName: menu2.py
- import wx
- class MyMenu(wx.Frame):
- def __init__(self, parent, ID, title):
- wx.Frame.__init__(self, parent, -1, title,
- wx.DefaultPosition, wx.Size(380, 250))
- menubar = wx.MenuBar()
- file = wx.Menu()
- edit = wx.Menu()
- help = wx.Menu()
- file.Append(101, '&Open', 'Open a new document')
- file.Append(102, '&Save', 'Save the document')
- file.AppendSeparator()
- quit = wx.MenuItem(file, 105, '&Quit\tCtrl+Q', 'Quit the Application')
- quit.SetBitmap(wx.Image ('gtk-quit.png',
- wx.BITMAP_TYPE_PNG).ConvertToBitmap())
- file.AppendItem(quit)
- edit.Append(201, 'check item1', '', wx.ITEM_CHECK)
- edit.Append(202, 'check item2', kind= wx.ITEM_CHECK)
- submenu = wx.Menu()
- submenu.Append(301, 'radio item1', kind=wx.ITEM_RADIO)
- submenu.Append(302, 'radio item2', kind=wx.ITEM_RADIO)
- submenu.Append(303, 'radio item3', kind= wx.ITEM_RADIO)
- edit.AppendMenu(203, 'submenu', submenu)
- menubar.Append(file, '&File')
- menubar.Append(edit, '&Edit')
- menubar.Append(help, '&Help')
- self.SetMenuBar(menubar)
- self.Centre()
- wx.EVT_MENU(self, 105, self.OnQuit)
- def OnQuit(self, event):
- self.Close()
- class MyApp(wx.App):
- def OnInit(self):
- frame = MyMenu(None, -1, 'menu2.py')
- frame.Show(True)
- return True
- app = MyApp(0)
- app.MainLoop()
======================================================================
- #!/usr/bin/env python
- # FileName: toolbar.py
- import wx
- class MyToolBar( wx.Frame ):
- def __init__( self, parent, ID, title ):
- wx.Frame.__init__( self, parent, ID, title, wx.DefaultPosition, wx.Size( 350, 250 ) )
- vbox = wx.BoxSizer( wx.VERTICAL )
- toolbar = wx.ToolBar( self, -1, style=wx.TB_HORIZONTAL | wx.NO_BORDER )
- toolbar.AddSimpleTool( 1, wx.Image( 'stock_new.png', wx.BITMAP_TYPE_PNG ).ConvertToBitmap(), 'New', '' )
- toolbar.AddSimpleTool( 2, wx.Image( 'stock_open.png', wx.BITMAP_TYPE_PNG ).ConvertToBitmap(), 'Opne', '' )
- toolbar.AddSimpleTool( 3, wx.Image( 'stock_save.png', wx.BITMAP_TYPE_PNG ).ConvertToBitmap(), 'Save', '' )
- toolbar.AddSeparator()
- toolbar.AddSimpleTool( 4, wx.Image( 'stock_exit.png', wx.BITMAP_TYPE_PNG ).ConvertToBitmap(), 'Exit', '' )
- toolbar.Realize()
- vbox.Add( toolbar, 0, border=5 )
- self.SetSizer( vbox )
- self.statusbar = self.CreateStatusBar()
- self.Centre()
- wx.EVT_TOOL( self, 1, self.OnNew )
- wx.EVT_TOOL( self, 2, self.OnOpen )
- wx.EVT_TOOL( self, 3, self.OnSave )
- wx.EVT_TOOL( self, 4, self.OnExit )
- def OnNew( self, event ):
- self.statusbar.SetStatusText( 'New Command' )
- def OnOpen( self, event ):
- self.statusbar.SetStatusText( 'Open Command' )
- def OnSave( self, event ):
- self.statusbar.SetStatusText( 'Save Command' )
- def OnExit( self, event ):
- self.Close()
- class MyApp( wx.App ):
- def OnInit( self ):
- frame = MyToolBar( None, -1, ' toolbar.py' )
- frame.Show( True )
- return True
- app = MyApp( 0 )
- app.MainLoop()
======================================================================
有两种基本的方法可以用来布置我们的构件。第一种是手工布置。我们通过在构造器中指定位置来摆放我们的构件。
- #!/usr/bin/evn python
- import wx
- class MyFrame(wx.Frame):
- def __init__(self,parent,ID,title):
- wx.Frame.__init__(self,parent,ID,title,wx.DefaultPosition,wx.Size(250,50))
- panel=wx.Panel(self,-1)
- wx.Button(panel,-1,'Button1',(0,0))
- wx.Button(panel,-1,'Button2',(80,0))
- wx.Button(panel,-1,'Button3',(160,0))
- class MyApp(wx.App):
- def OnInit(self):
- frame=MyFrame(None,-1,'layout.py')
- frame.Show(True)
- frame.Centre()
- app = MyApp(0)
- app.MainLoop()
* wx.StaticBoxSizer
* wx.GridSizer
* wx.GridBagSizer
======================================================================
我们来写一个程序,它的窗口顶部的一行被三个按纽占据。这些按纽会随窗口的改变而改变。
- #!/usr/bin/env python
- # FileName: wxboxsizer.py
- import wx
- class MyFrame(wx.Frame):
- def __init__(self,parent,ID,title):
- wx.Frame.__init__(self,parent,ID,title,(-1,-1),wx.Size(250,50))
- panel=wx.Panel(self,-1)
- box=wx.BoxSizer(wx.HORIZONTAL)
- box.Add( wx.Button( panel, -1, 'Button1' ), 1 )
- box.Add( wx.Button( panel, -1, 'Button2' ), 1 )
- box.Add( wx.Button( panel, -1, 'Button3' ), 1 )
- panel.SetSizer(box)
- self.Centre()
- class MyApp(wx.App):
- def OnInit(self):
- frame = MyFrame( None, -1, 'wxboxsizer.py' )
- frame.Show(True)
- return True
- app = MyApp(0)
- app.MainLoop()
* wx.RIGHT
* wx.BOTTOM
* wx.TOP
* wx.ALL
* wx.ALIGN_RIGHT
* wx.ALIGN_TOP
* wx.ALIGN_BOTTOM
* wx.ALIGN_CENTER_VERTICAL
* wx.ALIGN_CENTER_HORIZONTAL
* wx.ALIGN_CENTER
- #!/usr/bin/python
- # FileName: layout3.py
- import wx
- class MyFrame( wx.Frame ):
- def __init__( self, parent, ID, title ):
- wx.Frame.__init__(self,parent,ID,title,(-1,-1),wx.Size(450,300))
- panel = wx.Panel(self,-1)
- box = wx.BoxSizer( wx.HORIZONTAL )
- box.Add( wx.Button( panel, -1, 'Button1' ), 1, wx.ALL, 5 )
- box.Add( wx.Button( panel, -1, 'Button2' ), 0, wx.EXPAND )
- box.Add( wx.Button( panel, -1, 'Button3' ), 0, wx.ALIGN_CENTER )
- panel.SetSizer( box )
- self.Center()
- class MyApp( wx.App ):
- def OnInit( self ):
- frame = MyFrame( None, -1, 'layout3.py' )
- frame.Show( True )
- return True
- app = My App( 0 )
- app.MainLoop()
- #!/usr/bin/env python
- # FileName: borders.py
- import wx
- class MyFrame( wx.Frame ):
- def __init__( self, parent, id, title ):
- wx.Frame.__init__( self, parent, id, title )
- vbox = wx.BoxSizer( wx.VERTICAL )
- hbox1 = wx.BoxSizer( wx.HORIZONTAL )
- hbox2 = wx.BoxSizer( wx.HORIZONTAL )
- pnl1 = wx.Panel( self, -1, style=wx.SIMPLE_BORDER )
- pnl2 = wx.Panel( self, -1, style=wx.RAISED_BORDER )
- pnl3 = wx.Panel( self, -1, style=wx.SUNKEN_BORDER )
- pnl4 = wx.Panel( self, -1, style=wx.DOUBLE_BORDER )
- pnl5 = wx.Panel( self, -1, style=wx.STATIC_BORDER )
- pnl6 = wx.Panel( self, -1, style=wx.NO_BORDER )
- hbox1.Add( pnl1, 1, wx.EXPAND | wx.ALL, 3 )
- hbox1.Add( pnl2, 1, wx.EXPAND | wx.ALL, 3 )
- hbox1.Add( pnl3, 1, wx.EXPAND | wx.ALL, 3 )
- hbox2.Add( pnl4, 1, wx.EXPAND | wx.ALL, 3 )
- hbox2.Add( pnl5, 1, wx.EXPAND | wx.ALL, 3 )
- hbox2.Add( pnl6, 1, wx.EXPAND | wx.ALL, 3 )
- vbox.Add( hbox1, 1, wx.EXPAND )
- vbox.Add( hbox2, 1, wx.EXPAND )
- self.SetSizer( vbox )
- self.Centre()
- class MyApp( wx.App ):
- def OnInit( self ):
- frame = MyFrame( None, -1, 'borders.py' )
- frame.Show( True )
- return True
- app = MyApp( 0 )
- app.MainLoop()
* wx.RAISED_BORDER
* wx.SUNKEN_BORDER
* wx.DOUBLE_BORDER
* wx.STATIC_BORDER
* wx.NO_BORDER
======================================================================
wx.GridSizer 使用两维的表格来布局它里面的东西。每个表格的宽度等于它里面最大那个构件的宽度,高度等于它里面高度最大的那个构件的高度。
- #!/usr/bin/env python
- # FileName: calculator.py
- import wx
- class MyFrame( wx.Frame ):
- def __init__( self, parent, id, title ):
- wx.Frame.__init__(self,parent,id,title,wx.DefaultPosition,wx.Size(300, 250))
- self.formula = False
- menubar = wx.MenuBar()
- file = wx.Menu()
- file.Append( 22, '&Quit', 'Exit Calculator' )
- menubar.Append( file, '&File' )
- self.SetMenuBar( menubar )
- wx.EVT_MENU( self, 22, self.OnClose )
- sizer = wx.BoxSizer( wx.VERTICAL )
- self.display = wx.TextCtrl(self, -1, '', style=wx.TE_RIGHT)
- sizer.Add(self.display, 0, wx.EXPAND|wx.TOP|wx.BOTTOM, 4)
- gs = wx.GridSizer(4, 4, 3, 3)
- gs.AddMany([(wx.Button(self, 20, 'Cls'), 0, wx.EXPAND),
- (wx.Button(self, 21, 'Bck'), 0, wx.EXPAND),
- (wx.StaticText(self, -1, ''), 0, wx.EXPAND),
- (wx.Button(self, 22, 'Close'), 0, wx.EXPAND),
- (wx.Button(self, 1, '7'), 0, wx.EXPAND),
- (wx.Button(self, 2, '8'), 0, wx.EXPAND),
- (wx.Button(self, 3, '9'), 0, wx.EXPAND),
- (wx.Button(self, 4, '/'), 0, wx.EXPAND),
- (wx.Button(self, 5, '4'), 0, wx.EXPAND),
- (wx.Button(self, 6, '5'), 0, wx.EXPAND),
- (wx.Button(self, 7, '6'), 0, wx.EXPAND),
- (wx.Button(self, 8, '*'), 0, wx.EXPAND),
- (wx.Button(self, 9, '1'), 0, wx.EXPAND),
- (wx.Button(self, 10, '2'), 0, wx.EXPAND),
- (wx.Button(self, 11, '3'), 0, wx.EXPAND),
- (wx.Button(self, 12, '-'), 0, wx.EXPAND),
- (wx.Button(self, 13, '0'), 0, wx.EXPAND),
- (wx.Button(self, 14, '.'), 0, wx.EXPAND),
- (wx.Button(self, 15, '='), 0, wx.EXPAND),
- (wx.Button(self, 16, '+'), 0, wx.EXPAND)])
- sizer.Add(gs, 1, wx.EXPAND)
- self.SetSizer(sizer)
- self.Centre()
- wx.EVT_BUTTON(self, 20, self.OnClear)
- wx.EVT_BUTTON(self, 21, self.OnBackspace)
- wx.EVT_BUTTON(self, 22, self.OnClose)
- wx.EVT_BUTTON(self, 1, self.OnSeven)
- wx.EVT_BUTTON(self, 2, self.OnEight)
- wx.EVT_BUTTON(self, 3, self.OnNine)
- wx.EVT_BUTTON(self, 4, self.OnDivide)
- wx.EVT_BUTTON(self, 5, self.OnFour)
- wx.EVT_BUTTON(self, 6, self.OnFive)
- wx.EVT_BUTTON(self, 7, self.OnSix)
- wx.EVT_BUTTON(self, 8, self.OnMultiply)
- wx.EVT_BUTTON(self, 9, self.OnOne)
- wx.EVT_BUTTON(self, 10, self.OnTwo)
- wx.EVT_BUTTON(self, 11, self.OnThree)
- wx.EVT_BUTTON(self, 12, self.OnMinus)
- wx.EVT_BUTTON(self, 13, self.OnZero)
- wx.EVT_BUTTON(self, 14, self.OnDot)
- wx.EVT_BUTTON(self, 15, self.OnEqual)
- wx.EVT_BUTTON(self, 16, self.OnPlus)
- def OnClear(self, event):
- self.display.Clear()
- def OnBackspace(self, event):
- formula = self.display.GetValue()
- self.display.Clear()
- self.display.SetValue(formula[:-1])
- def OnClose(self, event):
- self.Close()
- def OnDivide(self, event):
- if self.formula:
- return
- self.display.AppendText('/')
- def OnMultiply(self, event):
- if self.formula:
- return
- self.display.AppendText('*')
- def OnMinus(self, event):
- if self.formula:
- return
- self.display.AppendText('-')
- def OnPlus(self, event):
- if self.formula:
- return
- self.display.AppendText('+')
- def OnDot(self, event):
- if self.formula:
- return
- self.display.AppendText('.')
- def OnEqual(self, event):
- if self.formula:
- return
- formula = self.display.GetValue()
- self.formula = True
- try:
- self.display.Clear()
- output = eval(formula)
- self.display.AppendText(str(output))
- except StandardError:
- self.display.AppendText("Error")
- def OnZero(self, event):
- if self.formula:
- self.display.Clear()
- self.formula = False
- self.display.AppendText('0')
- def OnOne(self, event):
- if self.formula:
- self.display.Clear()
- self.formula = False
- self.display.AppendText('1')
- def OnTwo(self, event):
- if self.formula:
- self.display.Clear()
- self.formula = False
- self.display.AppendText('2')
- def OnThree(self, event):
- if self.formula:
- self.display.Clear()
- self.formula = False
- self.display.AppendText('3')
- def OnFour(self, event):
- if self.formula:
- self.display.Clear()
- self.formula = False
- self.display.AppendText('4')
- def OnFive(self, event):
- if self.formula:
- self.display.Clear()
- self.formula = False
- self.display.AppendText('5')
- def OnSix(self, event):
- if self.formula:
- self.display.Clear()
- self.formula = False
- self.display.AppendText('6')
- def OnSeven(self, event):
- if self.formula:
- self.display.Clear()
- self.formula = False
- self.display.AppendText('7')
- def OnEight(self, event):
- if self.formula:
- self.display.Clear()
- self.formula = False
- self.display.AppendText('8')
- def OnNine(self, event):
- if self.formula:
- self.display.Clear()
- self.formula = False
- self.display.AppendText('9')
- class MyApp(wx.App):
- def OnInit(self):
- frame = MyFrame(None, -1, "calculator.py")
- frame.Show(True)
- self.SetTopWindow(frame)
- return True
- app = MyApp(0)
- app.MainLoop()
wxPython中文教程 简单入门加实例的更多相关文章
- wxPython中文教程入门实例
这篇文章主要为大家分享下python编程中有关wxPython的中文教程,分享一些wxPython入门实例,有需要的朋友参考下 wxPython中文教程入门实例 wx.Window 是一个基类 ...
- BAT脚本编写教程简单入门篇
BAT脚本编写教程简单入门篇 批处理文件最常用的几个命令: echo表示显示此命令后的字符 echo on 表示在此语句后所有运行的命令都显示命令行本身 echo off 表示在此语句后所有运行的命 ...
- [转]Scrapy简单入门及实例讲解
Scrapy简单入门及实例讲解 中文文档: http://scrapy-chs.readthedocs.io/zh_CN/0.24/ Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用 ...
- Scrapy简单入门及实例讲解
Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 其可以应用在数据挖掘,信息处理或存储历史数据等一系列的程序中.其最初是为了页面抓取 (更确切来说, 网络抓取 )所设计的, 也可以 ...
- Scrapy简单入门及实例讲解-转载
Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 其可以应用在数据挖掘,信息处理或存储历史数据等一系列的程序中.其最初是为了页面抓取 (更确切来说, 网络抓取 )所设计的, 也可以 ...
- 10,Scrapy简单入门及实例讲解
Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 其可以应用在数据挖掘,信息处理或存储历史数据等一系列的程序中.其最初是为了页面抓取 (更确切来说, 网络抓取 )所设计的, 也可以 ...
- NinjaFramework中文教程(简单版)-手把手教程-从零开始
第一步: 官网http://www.ninjaframework.org/documentation/getting_started/create_your_first_application.htm ...
- JSTL简单入门学习实例
Maven依赖: <dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</ ...
- Expression Blend实例中文教程(11) - 视觉管理器快速入门Visual State Manager(VSM)
Expression Blend实例中文教程(11) - 视觉管理器快速入门Visual State Manager(V 时间:2010-04-12 16:06来源:SilverlightChina. ...
随机推荐
- Android中级教程之Android应用程序的生命周期
Android应用程序的生命周期图 在大部分情况下,每个Android应用都将运行在自己的Linux进程中.当这个应用的某些代码需要执行时,进程就会被创建,并且将保持运行,直到该进程不再需要,而系统需 ...
- 关于json数据中的多反斜杆转译--StringEscapeUtils.unescapeJava(踩过的坑)
一.需求 现有一个字符串str String str = "{\\\"name\\\":\\\"spy\\\",\\\"id\\\\&quo ...
- Python 枚举类源码解析
1. EnumMeta 元类编程,生成类的类,可以动态生成类. 用法: type(name, bases, dict) name -> 类名: str bases -> 基类: tuple ...
- CMSIS-DAP仿真器_学习(转载)
先给大家普及一下,哈哈.CMSIS-DAP仿真器,是ARM官方做的开源仿真器,没有版权,自由制作.官方给的源代码,使用的是NXP的单片机LPC4320做的.这个源代码,只要你安装了KEIL5,就可以找 ...
- python week09 Mysql 数据库基础知识
第一篇:初识数据库 注:<基础概念,不再赘述,点开链接查看> 第二篇:库相关操作 一 系统数据库 information_schema: 虚拟库,不占用磁盘空间,存储的是数据库启动后的一些 ...
- 【SDOI2009】HH的项链 线段树
题目描述 HH 有一串由各种漂亮的贝壳组成的项链.HH 相信不同的贝壳会带来好运,所以每次散步完后,他都会随意取出一段贝壳,思考它们所表达的含义.HH 不断地收集新的贝壳,因此,他的项链变得越来越长. ...
- Hadoop架构的初略总结(2)
Hadoop架构的初略总结(2) 回顾一下前文,我们总结了以下几个方面.我们为什么需要Hadoop:Hadoop2.0生态系统的构成:Hadoop1.0中HDFS和MapReduce的结构模型. 我们 ...
- Leetcode 543.二叉树的直径
二叉树的直径 给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过根结点. 示例 :给定二叉树 1 / \ 2 3 / \ 4 5 返回 3, ...
- [oldboy-django][6其他]学习django网站推荐
http://www.cnblogs.com/holbrook/archive/2012/02/19/2358704.html alex: http://www.cnblogs.com/alex371 ...
- [python][django学习篇][15]博客侧栏--自定义模板标签
我们的博客侧边栏有四项内容:最新文章.归档.分类和标签云. 这些内容相对比较固定,且在各个页面都会显示,如果像文章列表或者文章详情一样,从视图函数中获取然后传递给模板,则每个页面对应的视图函数里都要写 ...