Python导出Excel为Lua/Json/Xml实例教程(一):初识Python

   2023-02-08 学习力0
核心提示:相关链接:Python导出Excel为Lua/Json/Xml实例教程(一):初识PythonPython导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验Python导出Excel为Lua/Json/Xml实例教程(三):终极需求一、Why无论做什么事,一定有个理由,所以第一步,我来简述一下Why,为什

相关链接:

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")
    

下图左侧为代码,右侧为执行结果(截图的时候不小心删掉了部分代码)。

Python导出Excel为Lua/Json/Xml实例教程(一):初识Python

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循环结束")
    

执行结果如下:

Python导出Excel为Lua/Json/Xml实例教程(一):初识Python


**将代码变形一下,再加上一个判断和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循环结束")
    

执行结果如下:

Python导出Excel为Lua/Json/Xml实例教程(一):初识Python

可以看到当循环到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的文件

Python导出Excel为Lua/Json/Xml实例教程(一):初识Python

6.总结

到目前为止,我们已经掌握了python的基本用法,也能够将数据写入文件,下一篇我们将会开始操作excel文件。

更多链接:

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

 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • LUA解析json小demo
    需要修改的json数据gui-config.json{"configs": [{"server": "JP3.ISS.TF","server_port": 443,"password": "58603228","method": "aes-256-cfb","remarks": ""},{"serv
    03-16
  • 第二十三篇:在SOUI中使用LUA脚本开发界面
    像写网页一样做客户端界面可能是很多客户端开发的理想。做好一个可以实现和用户交互的动态网页应该包含两个部分:使用html做网页的布局,使用脚本如vbscript,javascript做用户交互的逻辑。当需求变化时,只需要在服务端把相关代码调整一下,用户即可看到新的
    03-16
  • windows下编译lua源码"><转>windows下编译lua源
    因为之前一直使用 lua for windows 来搭建lua的使用环境,但是最新的 lua for windows 还没有lua5.2,我又想用这个版本的lua,所以被逼无奈只能自己编一下lua源码。首先从 lua的官网 下载你想要使用的lua源码,比如我下载的就是lua5.2。解压后内容如下:
    03-16
  • lua:使用Lua处理游戏数据
    在之前lua学习:lua作配置文件里,我们学会了用lua作配置文件。其实lua在游戏开发中可以作为一个强大的保存、载入游戏数据的工具。 比如说,现在我有一份表单:data.xls用什么工具解析这个Excel文件并将数据载入游戏?我们可以使用Lua来完成这个工作。不过要
    03-16
  • 第1课 - 学习 Lua 的意义
    第1课 - 学习 Lua 的意义
    第1课 - 学习 Lua 的意义1.Lua 简介           (1) 1993年、巴西(2) 小巧精致的脚本语言,大小只有 200K(3) 用标准C语言写成,能够在所有的平台上编译运行(4) 发明的目标是嵌入在C/C++中,为应用程序提供灵活的扩展和定制功能(5) 不适合用于开发
    03-16
  • RedisTemplate 常用API+事务+陷阱+序列化+pipeline+LUA
    RedisTemplate 常用API+事务+陷阱+序列化+pipel
    https://www.jianshu.com/p/7bf5dc61ca06/https://blog.csdn.net/qq_34021712/article/details/79606551https://www.jianshu.com/p/c9f5718e58f0dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-data-redis/artifactId/depe
    03-08
  • Nginx动态路由的新姿势:使用Go取代lua nginx路由规则
    Nginx动态路由的新姿势:使用Go取代lua nginx路
    导语: 在Nitro 中, 我们需要一款专业的负载均衡器。 经过一番研究之后,Mihai Todor和我使用Go构建了基于Nginx、Redis 协议的路由器解决方案,其中nginx负责所有繁重工作,路由器本身并不承载流量。 这个解决方案过去一年在生产环境中运行顺畅。 以下是我
    03-08
  • cocos2d-lua 控制台输入Lua指令方便调试
    用脚本进行开发,如果不能实时去输入指令,就丧失了脚本的一大特色,所以对cocos2d-x程序稍微修改下,使其可以直接从控制台读入lua指令,方便调试。1 首先在行首加入lua的引用,如下1 #include "main.h"2 #include "AppDelegate.h"3 #include "cocos2d.h"4 #i
    02-09
  • lua_touserdata
    void *lua_touserdata(lua_State*L,intindex);如果给定索引处的值是一个完整的userdata,函数返回内存块的地址。如果值是一个lightuserdata,那么就返回它表示的指针。否则,返回NULL。例如: 在CCLuaStack::executeFunction()函数中有一段代码是用来获取c++
    02-09
  • Lua 5.2 中文参考手册
    闲来无事,发现Lua更新到了5.2.2,参考手册也更到了5.2,在网上发现只有云风翻译的5.1版,花了几天时间翻译了一些。参考手册有点长,又要随时修改,所以在github上建了项目,有需要的朋友可以看看,同时也欢迎指正。中文手册:Lua 5.2中文参考手册
    02-09
点击排行