公告:本站正式转型为非交互式静态网站!
转型:本站将通过笔记和博客的形式继续为大家服务,关于 Mathematica 问答服务请移步至QQ群:365716997
联系:如有问题请联系QQ群管理员,或发送邮件至:lixuan.xyz@qq.com。
感谢:最后非常感谢大家多年来的支持与帮助!
参考《互联网跟帖评论服务管理规定》《中华人民共和国网络安全法》《网络信息内容生态治理规定》《互联网用户账号信息管理规定》

—— 2022-11-27

欢迎来到 Mathematica 问答社区

提问时请贴上文本代码

语法高亮:在编辑器中点击

被禁止的话题:广告破解

请阅读:《提问的智慧》

备用域名:mma.ooo

支持LaTex数学公式
行内公式标识符:\$ 或“$\backslash ($”+“$\backslash )$”,
行间公式标识符:\$\$ 或 “$\backslash [$”+“$\backslash ]$”

社区建议QQ群:365716997

分类

0 投票
675 浏览

背景

由于计算量大,需要通过并行计算一些表达式,它们之间无关,也没有顺序要求。
需要把计算的结果保存至文件中(每个结果一行),或使用SQLite数据库中也行。

比如通过 OpenWrite 以流方式打开个一个文件,然后在 ParallelDo 中用 WriteLine 等函数向文件中写数据。

例子(测试用)

(*错误的例子*)
sw = OpenWrite["test.txt"];(*打开文件*)
ParallelDo[
 s = StringRiffle[{k, k^2, k^3}, "\t"];(*计算表达式*)
 WriteLine[sw, s];(*写文件*)
 , {k, 1, 10}];
Close[sw];
(*勉强可行的例子,但PutAppend存储的是Mma表达式,不爽还得二次编辑*)
ParallelDo[
  s = StringRiffle[{k, k^2, k^3}, "\t"];(*计算表达式*)
  s >>> "D:/test.txt"(*写文件*)
  , {k, 1, 10}];

 

用户: 野鹤 (5.1k 分)

登录 或者 注册 后回答这个问题。

...