Python导出Excel为Lua/Json/Xml实例教程(一):初识Python
Python导出Excel为Lua/Json/Xml实例教程(一):初识Python
相关链接:
Python导出Excel为Lua/Json/Xml实例教程(一):初识Python
Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验
Python导出Excel为Lua/Json/Xml实例教程(三):终极需求
一、Why
无论做什么事,一定有个理由,所以第一步,我来简述一下Why,为什么会有这个需求。
做过游戏的朋友应该知道,游戏当中很多的数据都是通过策划配置在Excel表格中的,而为了使用excel表格中的数据,就需要把excel导出为程序可以识别的格式。
程序中用来存储数据的格式一般为Xml和Json,当然,只要你开心,你也可以用二进制或是txt存储。
无论是导出xml还是json还是其他,只要掌握了原理,导出什么都可以。由于我目前的项目是用Lua来写手机游戏,我就以导出Lua为例来讲解如何通过Python来导出Excel。
二、Python基础
Python(英语发音:/ˈpaɪθən/), 是一种面向对象、解释型计算机程序设计语言。
有Python基础的朋友建议跳过此小节,进入后续文章。
正是因为Python简单优雅,使用方便,因此博主选择了它作为导出Excel的语言,当然,用PHP、GO、VBA等都能优雅地完成这个需求。
如果你没有任何语言基础,建议跳过本文先去看看完整的Python中文手册
如果已经有了一定的语言基础,但并没有接触过python,那么你只需要掌握下文中列出的几条便足够实现需求了。
如果已经有了python基础,那么可以直接移步教程第二部分:Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验
1.安装Python
- Windows:在Python官网下载对应的安装包,然后安装即可。
- Macos:自带2.7版本的python,so easy,
博主接下来是以基于Macos的环境实现并测试通过,windows环境并未实测。
2.HelloWorld!
- 用你的魔法在桌面上创建一个叫"
test.py"的文件 - 在文件中写上一行:
print("HelloWorld") - 打开终端键入命令:
python /Users/你的名字/Desktop/test.py - 轻敲
回车,搞定。
print("HelloWorld")
下图左侧为代码,右侧为执行结果(截图的时候不小心删掉了部分代码)。

3.几个要点
- 语句结束无需分号
- Python是用缩进来区分代码段落
(Python开发者有意让违反了缩进规则的程序不能通过编译,以此来强制程序员养成良好的编程习惯。并且Python语言利用缩进表示语句块的开始和退出(Off-side规则),而非使用花括号或者某种关键字。增加缩进表示语句块的开始,而减少缩进则表示语句块的退出) - 缩进要严格统一,不能空格和TAB混用
(如果遇到莫名其妙的编译错误,一定要检查这一条!博主就在这条上吃了亏。) - 若要在代码中直接写中文,需要加上一句
# -*- coding: UTF-8 -*- - py是弱类型语言,变量无需类型申明
4.练习一:基本语法
- int转String:
str(数字) - String转int:
int(字串) - if 语句:
if条件1:执行1elif条件2:执行2else:执行3 - for循环:
for元素in数组:执行循环else:循环结束执行 - for循环:
foriinrange(1, 20, 3):(从1到20,以3为步长进行循环) - for循环的else是可选的,如果循环未被break终止,则执行else块中的语句。
- continue和其他语言一样是跳过后面的代码,开始下一轮循环
# Author:Krisik
# 博客地址:http://www.cnblogs.com/krisirk/
# -*- coding: UTF-8 -*-
# 这句话是让你在本文件中直接写中文
for i in range(1,20,3):
if i % 2 == 0 :
print("我是偶数:" + str(i))
else:
print("我是奇数:" + str(i))
else:
print("for循环结束")
执行结果如下:

**将代码变形一下,再加上一个判断和break,看看会发生什么**
# Author:Krisik
# 博客地址:http://www.cnblogs.com/krisirk/
# -*- coding: UTF-8 -*-
# 这句话是让你在本文件中直接写中文
for i in range(1,20,3):
if i == 16 :
break
elif i % 2 == 0 :
print("我是偶数:" + str(i))
else:
print("我是奇数:" + str(i))
else:
print("for循环结束")
执行结果如下:

可以看到当循环到16,执行break以后,并没有打印19,而且else语句块也没有执行了。
5.练习二:写文件
- 需要引入库
import os - 新建或者打开文件:
file = open(路径,'w') - 向文件中写入数据:
file.write('数据')(file为上一步新建的文件) - 写入完毕,关闭文件:
file.close()
接下来我们用python在桌面创建一个test.lua的文件,然后往里面写入一个字符串
# Author:Krisik
# 博客地址:http://www.cnblogs.com/krisirk/
import os
file = open('/Users/kris/Desktop/test.lua','w')
file.write("Hello lua")
file.close()
执行过后,在桌面就会出现一个叫做test.lua的文件

6.总结
到目前为止,我们已经掌握了python的基本用法,也能够将数据写入文件,下一篇我们将会开始操作excel文件。
更多链接:
Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验
Python导出Excel为Lua/Json/Xml实例教程(一):初识Python的更多相关文章
- Python导出Excel为Lua/Json/Xml实例教程(三):终极需求
相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验 Python导出E ...
- Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验
Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验 相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出E ...
- 导出Excel/Pdf/txt/json/XML/PNG/CSV/SQL/MS-Word/ Ms-Powerpoint/等通过tableExport.js插件来实现
首先去我的云盘下载需要的js: 链接:https://pan.baidu.com/s/13vC-u92ulpx3RbljsuadWw 提取码:mo8m 页面代码: <!DOCTYPE html& ...
- phpExcel导出excel加超级链接的实例代码[转]
phpexcel实现的导出excel文件的代码,且可以在excel文件中加入超级链接. 说明:PHPExcel的开发包Tests目录有详细使用实例.以下代码支持中文,注意文件编码,文件保存为utf-8 ...
- springMVC中使用POI方式导出excel至客户端、服务器实例
Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能. 这里的方法支持导出excel至项目所在服务器,或导 ...
- 序列化各个类型成JSON XML实例
LitJson组件序列化请参考http://www.cnblogs.com/leee/p/4437230.html XML序列化请参考http://www.cnblogs.com/leee/p/424 ...
- python 实现excel转化成json文件
1.准备工作 python 2.7 安装 安装xlrd -- pip install xlrd 2. 直接上代码 import xlrd from collections import Ordered ...
- python读取excel数据为json格式(兼容xls\xlsx)
做自动化时需要从excel读取数据: 本文实现将excel文件数据读取为json格式,方便自动化调用 读取xls文件 使用xlrd读取xls文件代码: import xlrd def read_xls ...
- POI导出excel项目(webwork)实例
后台action: public String exportExcel(){ this.setUserList(this.getUserService().findUserInfosByGroupID ...
随机推荐
- CI Weekly #6 | 再谈 Docker / CI / CD 实践经验
CI Weekly 围绕『 软件工程效率提升』 进行一系列技术内容分享,包括国内外持续集成.持续交付,持续部署.自动化测试. DevOps 等实践教程.工具与资源,以及一些工程师文化相关的程序员 Ti ...
- JavaScript随笔5
事件(1) 鼠标的点击坐标: 火狐不支持 IE event.clientX//可视区坐标 event.clientY FF ev.clientX ev.clientY 兼容: var oEvent = ...
- NotePad++中JSLint的使用
1.第一步下载Notepad++ 2.安装JSLint插件 3.运行JSlint 4.前提是你设置了当前语言或者本身文件就是js 5.JSLint的作用主要就是检查你的JS的规则正确性(至少是绝大部分 ...
- 前端学HTTP之代理
前面的话 Web代理(proxy)服务器是网络的中间实体,位于客户端和服务器之间,扮演“中间人”的角色,在各端点之间来回传送HTTP报文.本文将介绍HTTP代理服务器相关内容 中间实体 Web上的代理 ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(38)-Easyui-accordion+tree漂亮的菜单导航
系列目录 本节主要知识点是easyui 的手风琴加树结构做菜单导航 有园友抱怨原来菜单非常难看,但是基于原有树形无限级别的设计,没有办法只能已树形展示 先来看原来的效果 改变后的效果,当然我已经做好了 ...
- Vertica 安装,建库,新建测试用户并授予权限,建表,入库
测试环境:RHEL 6.4 + Vertica 6.1.3-7 需求:搭建Vertica数据库3节点的测试环境,建立测试用户,建表,测试数据入库. 1.各节点关闭防火墙和SELinux,配置主机名,I ...
- DotNet生成随机数的一些方法
在项目开发中,一般都会使用到“随机数”,但是在DotNet中的随机数并非真正的随机数,可在一些情况下生成重复的数字,现在总结一下在项目中生成随机数的方法. 1.随机布尔值: /// <summa ...
- Basic Tutorials of Redis(6) - List
Redis's List is different from C#'s List,but similar with C#'s LinkedList.Sometimes I confuse with t ...
- 分享一个php邮件库——swiftmailer
最近看到一个好的php邮件库,与phpmailer作用一样,但性能比phpmailer好,尤其是在处理附件的能力上,发送邮件成功的几率也高. github地址:https://github.com/s ...
- C++_系列自学课程_第_11_课_类型转换_《C++ Primer 第四版》
上次说了关于表达式的一些内容,说到还有一些关于数据类型转换的内容,今天我们接着八一八C++中的数据类型转换. 一.隐式类型转换 在表达式中,有些操作符可以对多种类型的操作数进行操作, 例如 + 操作符 ...