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等都能优雅地完成这个需求。

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 : 执行1 elif 条件2: 执行2 else: 执行3
  • for循环:for 元素 in 数组 : 执行循环 else: 循环结束执行
  • for循环:for i in range(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的更多相关文章

  1. Python导出Excel为Lua/Json/Xml实例教程(三):终极需求

    相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验 Python导出E ...

  2. Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验

    Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验 相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出E ...

  3. 导出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& ...

  4. phpExcel导出excel加超级链接的实例代码[转]

    phpexcel实现的导出excel文件的代码,且可以在excel文件中加入超级链接. 说明:PHPExcel的开发包Tests目录有详细使用实例.以下代码支持中文,注意文件编码,文件保存为utf-8 ...

  5. springMVC中使用POI方式导出excel至客户端、服务器实例

    Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能. 这里的方法支持导出excel至项目所在服务器,或导 ...

  6. 序列化各个类型成JSON XML实例

    LitJson组件序列化请参考http://www.cnblogs.com/leee/p/4437230.html XML序列化请参考http://www.cnblogs.com/leee/p/424 ...

  7. python 实现excel转化成json文件

    1.准备工作 python 2.7 安装 安装xlrd -- pip install xlrd 2. 直接上代码 import xlrd from collections import Ordered ...

  8. python读取excel数据为json格式(兼容xls\xlsx)

    做自动化时需要从excel读取数据: 本文实现将excel文件数据读取为json格式,方便自动化调用 读取xls文件 使用xlrd读取xls文件代码: import xlrd def read_xls ...

  9. POI导出excel项目(webwork)实例

    后台action: public String exportExcel(){ this.setUserList(this.getUserService().findUserInfosByGroupID ...

随机推荐

  1. ABP源码分析二十八:ABP.MemoryDB

    这个模块简单,且无实际作用.一般实际项目中都有用数据库做持久化,用了数据库就无法用这个MemoryDB 模块了.原因在于ABP限制了UnitOfWork的类型只能有一个(前文以作介绍),一般用了数据库 ...

  2. AKKA 笔记 - 有限状态机 -2

    AKKA 笔记 - 有限状态机 -2 原文地址: http://rerun.me/2016/05/22/akka-notes-finite-state-machines-2/ 在上一节的Akka FS ...

  3. Material Design Reveal effect(揭示效果) 你可能见过但是叫不出名字的小效果

    Material Design Reveal effect(揭示效果) 你可能见过但是叫不出名字的小效果 前言: 每次写之前都会来一段(废)话.{心塞...} Google Play首页两个tab背景 ...

  4. javascript关于立即函数

    以前的知识总是忘,遇到代码又看不懂.要再复习一下,顺便记录一下. 关于立即执行函数:  函数声明:function fnName () {…};使用function关键字声明一个函数,再指定一个函数名 ...

  5. python资料

    Python进阶 https://pythontips.com/ https://flyouting.gitbooks.io/learn-python-the-hard-way-cn/content/ ...

  6. Uncaught RangeError: Maximum call stack size exceeded 调试日记

    异常处理汇总-前端系列 http://www.cnblogs.com/dunitian/p/4523015.html 开发道路上不是解决问题最重要,而是解决问题的过程,这个过程我们称之为~~~调试 记 ...

  7. MySQL升级

    MySQL的升级相对来说还是比较简单的. 它支持两种方式的升级: 原地升级(In-place Upgrade) 关闭数据库,替换旧的二进制文件,重启数据库,执行mysql_upgrade 逻辑升级(L ...

  8. ASP.NET Core 阶段性总结

    自从年前用 ASP.NET 5 磕磕绊绊重写了一个项目后 (2015.12),就没怎么关注 ASP.NET 5 相关内容了,为啥?因为实际应用问题太多,而且不是正式版本,变化实在太快,可能你今天了解的 ...

  9. YYModel 源码解读(一)之YYModel.h

    #if __has_include(<YYModel/YYModel.h>) FOUNDATION_EXPORT double YYModelVersionNumber; FOUNDATI ...

  10. Oracle 11.2.0.4 RAC安装最新PSU补丁

    环境:两节点RAC(RHEL 6.4 + GI 11.2.0.4 + Oracle 11.2.0.4) 需求:安装最新PSU补丁11.2.0.4.7 1.下载补丁和最新OPatch 2.检查数据库当前 ...