- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在开发一个 Flutter 应用程序,并想编写一个构建脚本来将某种原始文件(CSV 格式)转换为格式化的 JSON 文件,以作为 Flutter Assets 包含在内。
通过使用像 json_serializable
和 jaguar_serializer
这样的库,我了解了 build_runner
,所以看起来我要编写自己的 Builder
并通过 build_runner
调用它是一种明智的方式。
由于有关编写我们自己的构建脚本的资源非常有限,我首先修改找到的示例 here .但是我在尝试更改输入和输出文件的路径时卡住了:当我运行 flutter pub pub run build_runner build
时,结果发现 Dart 仅在 [ project_dir]/web
目录,只允许我将文件写入此 web
目录。所以这段代码
buildStep.writeAsString(new AssetId(buildStep.inputId.package, 'assets/resources/foo.json'), '[]');
将产生以下异常:
UnexpectedOutputException: myapp|assets/resources/foo.json
Expected only: {myapp|web/.json}
[SEVERE] Failed after 24.4s
json_serializable
和 jaguar_serializer
可以在任何地方自由生成代码这一事实似乎表明我的配置存在问题。但是我在我的代码和 build.yaml
文件中的任何地方都找不到这个 web
东西,所以这真的很令人费解。
FWIW,这是我的 builder.yaml
文件的内容:
builders:
jsonBuilder:
import: "package:myapp/builder.dart"
builder_factories: ["jsonFileBuilder"]
build_extensions: {"source.csv": [".json"]}
build_to: source
auto_apply: root_package
这是 builder.dart
文件
import 'dart:async';
import 'package:build/build.dart';
Builder jsonFileBuilder(BuilderOptions options) => new JsonFileBuilder();
class JsonFileBuilder implements Builder {
@override
Future build(BuildStep buildStep) async {
await buildStep.writeAsString(
new AssetId(buildStep.inputId.package, 'assets/resources/foo.json'),
'hello');
}
@override
final buildExtensions = const {
'source.csv': const ['.json']
};
}
提前致谢!
最佳答案
好吧,看来这个问题实际上是双重的。
我的问题是,如果我将源 CSV 文件放在某个任意目录下(例如 offline
),我的构建脚本将不会运行,因为没有找到匹配的文件。但是当我将文件放在 web
下时(如示例中所示),脚本将被调用。这让我产生了文件扫描仅限于web/
的错觉。事实上,有一个列表 hard-coded file/directory whitelist :
const List<String> _defaultRootPackageWhitelist = const [
'benchmark/**',
'bin/**',
'example/**',
'lib/**',
'test/**',
'tool/**',
'web/**',
'pubspec.yaml',
'pubspec.lock',
];
如果我将 CSV 文件放在 lib/
下,我的构建脚本也会被调用。
要将我的非白名单文件附加到列表中,我必须将以下部分添加到 build.yaml
。
targets:
$default:
sources:
# Need to replicate the default whitelist here or other build will break:
- "benchmark/**"
- "bin/**"
- "example/**"
- "lib/**"
- "test/**"
- "tool/**"
- "web/**"
- "pubspec.yaml"
- "pubspec.lock"
# My new source
- "offline/source.csv"
我的问题是我无法写入任意目录,构建系统一直提示我只能写入web/
。所以我以为文件写入被锁定到web/
。同样,这也不完全正确,因为文件写入实际上锁定到输入文件的目录。这意味着我只能在构建运行器成功识别此目录中的文件后才能写入 offline/
。
文件写入权限的检查由this method in build_step_impl.dart
控制:
void _checkOutput(AssetId id) {
if (!_expectedOutputs.contains(id)) {
throw new UnexpectedOutputException(id, expected: _expectedOutputs);
}
}
此 _expectedOutputs
是我的构建器类的 buildExtensions
映射的扁平化值。所以如果我真的想写入 assets/resources/foo.json
我必须这样写:
@override
final buildExtensions = const {
'source.csv': const ['/../../assets/resources/foo.json']
};
必须对 build.yaml
进行类似的调整:
build_extensions: {".csv": ["/../../assets/resources/foo.json"]}
这基本上解决了我的大部分问题,但还有一些问题:
首先,我打算编写一个读取单个文件并写入多个文件的构建脚本。文件的数量及其文件名取决于源文件的内容。鉴于检查代码,这似乎不是受支持的功能。不是障碍物,但有点不方便。
第二个是关于输出文件路径。您可以看到我的源文件位于 [projectDir]/offline
中,我想写入 [projectDir]/assets
,但输出文件名显示为 /。 ./../assets/...
,向上两层。这是因为原始文件名(没有扩展名)被添加到输出路径之前,这就是为什么人们会在生成 Dart 代码的构建器配置中看到 .g.dart
的原因。我需要编写 /../../assets
这样我的文件的完整输出路径将变为 [projectDir]/offline/source/../../assets
使其解析为所需的输出文件路径。但是默认行为给我的印象是构建系统不希望我的脚本写入当前文件目录之外的任何地方,而我所做的是对系统的黑客攻击或滥用。
关于Dart build_runner 只能扫描/读取/写入web/目录下的文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51188114/
我遇到以下问题。我想读取一个包含数百万行和数百列的大型 csv。我想向下转换列的数据类型。我的方法是读取 csv,然后使用 pd.to_numeric() 对其进行向下转换。我不知道列数及其类型。在读
目前,我从 SQL server (2008) 数据库获取数据。 cyurrent的方法是使用DataTable,然后将其传递并使用。 if (parameters != null)
我有以下问题。我有一个巨大的 csv 文件,想用多处理加载它。对于一个包含 500000 行和 130 列不同数据类型的示例文件,Pandas 需要 19 秒。我试过 dask 因为我想多处理阅读。但
是否有关于用于序列化各种 MFC 数据结构的二进制格式的明确文档?我已经能够在十六进制编辑器中查看我自己的一些类,并使用 Java 的 ByteBuffer 类读取它们(使用自动字节顺序转换等)。 但
我正在使用 Selenium 进行测试,我们用 HTML 文件编写测试用例,并用它们制作测试套件,我们的要求是编写足够健壮的测试用例,以根据测试环境改变自身。 为此,我不希望在 HTML 脚本本身中包
我需要一个 JavaScript 代码来读取存储为 .txt 文件的字典(或者也可以保存为任何其他类型的文件。它也可以在线获得)并将其内容存储在一个变量中。我不能找到一种让 JavaScript 像
我正在尝试遍历包含 SSH 登录和其他日志的日志文本文件。 程序正在返回 SSH 登录的总数。 我的解决方案确实有效,但似乎有点慢(在 200mo 文件上大约需要 3.5 秒)。我想知道是否有任何方法
我正在将大量数据从一个电子表格复制到工作簿中的其他 160 个电子表格。目前,Excel (2013) 遇到错误,因为它没有足够的资源来完成操作。 我的目标是将工作表 4 中 V13:XI1150 范
我正在尝试读取一个有 1147 行的文本文件。下面的代码仅读取第 1050-1147 行。我的目标是读取整个文件并提取位于不同行的特定值以在脚本中使用。一个示例是包含“BlockList: 2”的行中
我正在为游戏编写解释器。用户将其移动输入解释器,程序执行该移动。 现在我想为每个决定实现一个时间限制。玩家不应该能够思考超过 30 秒来写一个移动并按下回车。 call_with_time_limit
以this file例如,我正在尝试读取 data.frame 中的数据。来自 the doc (pdf 文件,表 1),它遵循一些 fortran 约定。我尝试了以下但收效甚微: dir 0' 将
我正在使用 R 阅读 Outlook 附件。我的引用在这里:Download attachment from an outlook email using R 这是我的电子邮件的截图: 这每天都会发送
我不会从表格中读取行来将主题放在列表中 php脚本 $url_obj='http://'.$host.':8069/xmlrpc/object'; $sock=new xmlrpc_client($u
我有一个这样的 csv 文件: id,name,value 1,peter,5 2,peter\,paul,3 我如何读取此文件并告诉 R "\," 不表示新列,仅表示 ","。 我必须添加该文件
我正在尝试读取 ~/Library/Preferences/com.apple.mail.plist (在 Snow Leopard 上)以获取电子邮件地址和其他信息以进入“关于”对话框。我使用以下代
This question already has answers here: How do I use floating-point division in bash? (19个回答) 5个月前关闭
本练习的目标是读取输入文件并将其存储到表中,然后验证输入中的某些字段并输出任何错误记录。我需要读取并存储每个策略组,以便表中一次仅存储 5 条记录,而不是整个文件。 所以我需要读取一个包含 5 条记录
据我了解,LWT 插入始终以 SERIAL 一致性级别完成。如果为 true,这是否意味着读取作为 LWT 插入的行可以安全地以 ANY 的一致性级别读取? 换句话说,我假设 LWT 插入是完全一致的
我看到很多很多通过java脚本读取cookie的函数,但我只想在变量中使用它一次,我是JS新手。 这是我的代码 var TheNumber = (Math.random() + '') * 10000
我正在使用 asp.net 和 C#。我在服务器上部署了一个应用程序[已发布],现在我想查看该网站的代码,据我所知,我可以阅读程序集来查看代码。 请告诉我如何实现它。 提前致谢。 最佳答案 您可以使用
我是一名优秀的程序员,十分优秀!