设为首页收藏本站|繁體中文

Project1

 找回密码
 注册会员
搜索
查看: 4259|回复: 5
打印 上一主题 下一主题

[推荐问答] RMXP脚本读取文档txt内容

[复制链接]

Lv1.梦旅人

梦石
0
星屑
85
在线时间
210 小时
注册时间
2013-7-26
帖子
346
跳转到指定楼层
1
发表于 2014-11-7 19:57:17 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

加入我们,或者,欢迎回来。

您需要 登录 才可以下载或查看,没有帐号?注册会员

x
获取文档txt 第一行的内容 第二行 第三行 分别被变量代入 ,  内容是"字符串",不是数值
求大神指点,在写一个非常重要的脚本。。@RyanBern  

点评

读取的这些不太懂,希望可以详细点  发表于 2014-11-7 19:57

Lv3.寻梦者 (版主)

…あたしは天使なんかじゃないわ

梦石
0
星屑
2208
在线时间
4033 小时
注册时间
2010-10-4
帖子
10779

开拓者贵宾

2
发表于 2014-11-7 20:05:30 手机端发表。 | 只看该作者
File.open('文件名.txt') do |f|
  line1 = f.gets
  line2 = f.gets
  line3 = f.gets
end

爪机写代码,打错勿怪。另外注意变量的作用域。

点评

VA也只有一个类而没有载入编码的so文件。不过File.open的参数里应该可以选择编码的,看Ruby1.8的文档吧。(不过GBK是妥妥地不支持)  发表于 2014-11-9 08:10
XD我为什么在XP中找不到Encoding这个类呢  发表于 2014-11-8 21:50
我说了我不清楚XP怎么弄  发表于 2014-11-8 16:38
等你有空了,发个详细的上来吧,谢谢  发表于 2014-11-8 16:15
不会。。  发表于 2014-11-8 16:14

评分

参与人数 2星屑 +200 梦石 +1 收起 理由
myownroc + 1 认可答案
RyanBern + 200 认可答案

查看全部评分

回复 支持 反对

使用道具 举报

Lv1.梦旅人

梦石
0
星屑
85
在线时间
210 小时
注册时间
2013-7-26
帖子
346
3
 楼主| 发表于 2014-11-8 12:57:08 | 只看该作者
@RyanBern 你有办法弄成中文的吗?
回复 支持 反对

使用道具 举报

Lv4.逐梦者

梦石
0
星屑
9280
在线时间
2504 小时
注册时间
2011-5-20
帖子
15389

开拓者

4
发表于 2014-11-8 13:11:19 | 只看该作者
夕仔 发表于 2014-11-7 19:57
@RyanBern 你有办法弄成中文的吗?

你@失败了···@
@RyanBern  你有办法弄成中文的吗?(地板)
这个只能用于读取数字 中文以及字母 不可以(沙发点评)
[img]http://service.t.sina.com.cn/widget/qmd/5339802982/c02e16bd/7.png
回复 支持 反对

使用道具 举报

Lv4.逐梦者 (版主)

梦石
0
星屑
9532
在线时间
5073 小时
注册时间
2013-6-21
帖子
3580

开拓者贵宾剧作品鉴家

5
发表于 2014-11-8 21:50:13 | 只看该作者
本帖最后由 RyanBern 于 2014-11-9 09:41 编辑

读不了中文的原因是文字编码方式不一致,Ruby脚本的默认编码方式是UTF-8,但是外部txt编码方式是ANSI,自然就乱码了。
貌似XP的Ruby版本还太低,好像不支持修改编码方式?(这个说不定只是我找不到而已)那既然如此只好修改外部txt编码方式了。
打开你的txt,点另存为,下面有个编码方式,选择UTF-8,覆盖原文件即可。

点评

手又抖了……  发表于 2014-11-9 09:40
泥萌很喜欢把 ANSI 和 ASCII 搞起来么= =  发表于 2014-11-9 08:44
可以了,谢谢,可是除了最后一行外,前面的末尾都有个 \n 出现  发表于 2014-11-9 00:11
想改用API还是能改的,不过最简单的还是更改文件的文字编码模式  发表于 2014-11-8 21:58

评分

参与人数 1梦石 +1 收起 理由
myownroc + 1 认可答案

查看全部评分

回复 支持 反对

使用道具 举报

Lv3.寻梦者

梦石
0
星屑
2749
在线时间
2630 小时
注册时间
2013-1-16
帖子
5657

贵宾

6
发表于 2014-11-9 01:17:03 | 只看该作者
本帖最后由 myownroc 于 2014-11-9 12:21 编辑

\n是换行符
<code>s = s.gsub(/\n/){""}
s.gsub!(/\n/){""}</code>
  1. s = s.gsub(/\n/){""}
  2. s.gsub!(/\n/){""}
  3. #其实chomp方法也可以
  4. s.chomp!
复制代码
这两条代码都可以将s中的\n去掉,选择一个就可以了。

点评

搞定了  发表于 2014-11-9 12:16
呃……<code>和</code>请无视掉  发表于 2014-11-9 11:45
两个都错误。。  发表于 2014-11-9 11:41
.chomp 一般更习惯用在gets.chomp中=_=  发表于 2014-11-9 11:32
谢谢  发表于 2014-11-9 11:31

评分

参与人数 1梦石 +1 收起 理由
RyanBern + 1 认可答案

查看全部评分

(Created by @喵kano)


施工现场:hotege.github.io
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册会员

本版积分规则

拿上你的纸笔,建造一个属于你的梦想世界,加入吧。
 注册会员
找回密码

站长信箱:[email protected]|手机版|小黑屋|无图版|Project1游戏制作

GMT+8, 2024-11-21 22:13

Powered by Discuz! X3.1

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表