背景:
    中午快餐,菜单吃了个遍,天天纠结于不知道点啥菜。 
    想起读书考试时,丢纸团选答案,于是用python写个随机点菜脚本玩玩。

功能:
      菜单为Excel,一个Sheet页为一个分类,每行显示每道菜的编号、菜名、价格,如下图所示。

1、程序启动,程序提示选择分类,按输入的数字进入相应分类所在Sheet页(目前分类写死,只有3类)。
     2、 程序获取Sheet页最大行数,以此为上限,随机生成一个1到最大行数之间的数字。
     3、程序根据生成的随机数,读出该行的菜名、价格。
     4、程序总计可随机选菜3次,3次后退出,每次提示是否继续,是则继续,否则程序立即退出。
     5、若所选分类所在Sheet页总行数小于3,不能满足3次随机,则程序提示并退出。
     6、输入时,程序检查输入合法性,并给出相应提示。

Python 2.7.5代码: 

 # coding=utf-8
import sys
import xlrd
import random
#打开菜单excel
workbook = xlrd.open_workbook('D:\\menu.xls')
#计数器为0
counters = 0
#默认继续
YesOrNo = 'y'
while 1:
#判断计数器,最多能选择3次
if counters<3:
#判断继续还是退出,默认是继续的
if YesOrNo=='y':
choose_num = raw_input('选择分类(1、小炒类|2、面食类|3、其他类):')
#判断选择的分类是否在三大类这中
if choose_num in ['','','']:
#根据选择的分类,进入到相应Sheet页
excel_sheet = workbook.sheet_by_index(int(choose_num)-1)
#获取Sheet页的行数和列数
nrows_num = excel_sheet.nrows
ncols_num = excel_sheet.ncols
print
if nrows_num>3:
#生成一个随机数
random_num = random.randint(1,nrows_num-1)
#根据生成的随机数,获取到该行的菜名
name = excel_sheet.row(random_num)[1].value
#根据生成的随机数,获取到该行的价格
price = excel_sheet.row(random_num)[2].value
#输出获取到的分类、菜名、价格
print '-----第',counters+1,'次随机点菜结果:-----'.decode('utf-8')
print ' 分类:',excel_sheet.name
print ' 菜名:',name
print ' 价格:'.decode('utf-8'),price,'元'.decode('utf-8')
#计数器+1
counters+=1
print
#提示是否继续?将输入内容英文小写化
YesOrNo = raw_input('是否继续?Y或N(不分大小写):').lower()
print
else:
print '该分类行数小于3,不支持3次随机,请修改!!!'
break
#判断输入的分类是否是1、2、3
else:
print ' 只能输入1、2、3,请重新输入!'
print
#判断是否继续输入n,则退出
elif YesOrNo=='n':
print '你选择了退出!'
break
#判断是否继续输入的值,非Y或N则继续要求输入
else :
print '只能输入Y或N,Try Again:'
print
YesOrNo = raw_input('是否继续?Y或N(不分大小写):').lower()
print
#判断计数器达到3次,程序退出
else:
print
print '你已经选了三次,还不能确定要吃啥?你直接吃粑粑去吧!!!'
break

测试:

1、正常流,输入分类,打印出随机得到的结果,计数器达3次,程序退出:
              

2、校验‘分类’输入非法(中文、英文、分类之外数字、浮点数)时,给出相应提示:
           

3、 校验‘是否继续’输入非法(中文、非Y或N之外的英文、浮点数)时,给出相应提示,输入N或n,则退出 :
          

4、行数小于3时,不能满足3次随机,给出相应提示,程序退出:
            
 
   5、重复选择同一分类,结果如下(此处存在随机数重复的Bug,有待改进):


      
       Bug:
         
       

Python操作Excel_随机点菜脚本的更多相关文章

  1. Python操作Excel_输出所有内容(包含中文)

    python 2.7.5代码: # coding=utf-8 import sys import xlrd data=xlrd.open_workbook('D:\\menu.xls') table ...

  2. Python操作12306抢票脚本

    有一段时间没有使用Python了,前几天经朋友提起一篇关于用Python实现抢火车票的文章,百度了实现抢火车票的技术细节,网上却有不少资料,也不是新鲜的东西.在了解了一些技术手段,阅读了一些大神的博文 ...

  3. Python之路:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy

    Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度 ...

  4. Python学习笔记 - day12 - Python操作NoSQL

    NoSQL(非关系型数据库) NoSQL,指的是非关系型的数据库.NoSQL有时也称作Not Only SQL的缩写,是对不同于传统的关系型数据库的数据库管理系统的统称.用于超大规模数据的存储.(例如 ...

  5. 【转】Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy

    Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度 ...

  6. python操作RabbitMQ(不错)

    一.rabbitmq RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统.他遵循Mozilla Public License开源协议. MQ全称为Message Queue, 消息队列 ...

  7. python操作RabbitMQ、Redis、Memcache、SQLAlchemy

    Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度 ...

  8. Python 【第六章】:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy

    Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度 ...

  9. Python操作RabbitMQ

    RabbitMQ介绍 RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现的产品,RabbitMQ是一个消息代理,从“生产者”接收消息并传递消 ...

随机推荐

  1. CI框架篇之基础篇(1)

    CodeIgniter 是一套给 PHP 网站开发者使用的应用程序开发框架和工具包.它提供一套丰富的标准库以及简单的接口和逻辑结构, 其目的是使开发人员更快速地进行项目开发.使用 CodeIgnite ...

  2. 《你不常用的c#之四》:Array的小抽屉ArraySegment

    转载自csdn:http://blog.csdn.net/robingaoxb/article/details/6200060 一:)略谈      ArraySegment顾名思义就是Array区块 ...

  3. python基础知识十一

    图形软件 使用Python的GUI库——你需要使用这些库来用Python语言创建你自己的图形程序.使用GUI库和它们的Python绑定,你可以创建你自己的IrfanView.Kuickshow软件或者 ...

  4. getSharedPreferences()与getSharedPreferences()与getDefaultSharedPreferences()的区别

    http://blog.csdn.net/ah200614435/article/details/7869681 一直迷惑于这三个方法的关系,最近忙完项目,好好的分析一下. 如果你熟悉Context那 ...

  5. 用Filezilla往ubuntu虚拟机上传文件

    也许不用这么复杂,但就这么干了 1.安卓ubuntu虚拟机 2.虚拟机安装ssh服务:sudo apt-get openssh-server 3.虚拟机新建目录test 4.修改test文件夹的访问权 ...

  6. OC加强-day02

    #program mark - 01 @class关键字 [掌握] 1.当两个头文件互相引用的时候,如果双方都是用#import来引入对方的头文件,就会造成死循环,编译不通过 解决方案:其中一边不要使 ...

  7. CSS 组合选择符

    CSS 组合选择符 组合选择符说明了两个选择器直接的关系. CSS组合选择符包括各种简单选择符的组合方式. 在 CSS3 中包含了四种组合方式: 后代选取器(以空格分隔) 子元素选择器(以大于号分隔) ...

  8. 初尝 MVC4

    文章内容参考 http://www.cnblogs.com/leoo2sk/archive/2008/10/27/1320285.html 开发环境 VS2010 ,VS2010 开发 MVC4 需下 ...

  9. 生产者与消费者(二)---await与 signal

    前面阐述了实现生产者与消费者问题的一种方式:wait() / notify()方法,本文继续阐述多线程的经典问题---生产者与消费者的第二种方式:await() / signal()方法. await ...

  10. php 解决大流量网站访问量问题

    当一个网站发展为知名网站的时候(如新浪,腾讯,网易,雅虎),网站的访问量通常都会非常大,如果使用虚拟主机的话,网站就会因为访问量过大而引起 服务器性能问题,这是很多人的烦恼,有人使用取消RSS等错误的 ...