- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我在 S3 上有一个大约 3 亿行的文本文件。我希望将此文件拆分为每个 1,000 行的较小文件(最后一个文件包含其余部分),然后我想将其放入 S3 上的另一个文件夹或存储桶中。
到目前为止,我一直在使用 linux 命令在我的本地驱动器上运行它:
split -l 1000 file
它将原始文件拆分为 1,000 行的较小文件。但是,对于这样一个较大的文件,从我的本地驱动器下载然后重新上传到 S3 似乎效率很低。
拆分此 S3 文件的最有效方法是什么,最好使用 Python(在 Lambda 函数中)或使用其他 S3 命令?在我的本地驱动器上运行它会更快吗?
最佳答案
您所做的任何操作都必须下载文件、拆分文件并重新上传。唯一的问题是在哪里,是否涉及本地磁盘。
John Rotenstein 为您提供了一个在 EC2 实例上使用本地磁盘的示例。这有在 AWS 数据中心运行的好处,因此它可以获得高速连接,但有以下限制:(1) 您需要磁盘空间来存储原始文件及其片段,以及 (2) 您需要一个 EC2 实例在哪里可以做到这一点。
一个小的优化是通过使用连字符作为 s3 cp
的目标来避免大文件的本地副本:这会将输出发送到标准输出,然后您可以通过管道它变成 split
(这里我还使用连字符告诉 split 从标准输入读取):
aws s3 cp s3://my-bucket/big-file.txt - | split -l 1000 - output.
aws s3 cp output.* s3://dest-bucket/
同样,这需要一个 EC2 实例来运行它,以及输出文件的存储空间。但是,split
有一个标志,可让您为拆分中的每个文件运行一个 shell 命令:
aws s3 cp s3://src-bucket/src-file - | split -b 1000 --filter 'aws s3 cp - s3://dst-bucket/result.$FILE' -
现在您已经解决了本地存储的问题,但剩下的问题是在何处运行它。我的建议是 AWS Batch ,它可以在执行命令所需的时间内启动 EC2 实例。
当然,您可以编写一个 Python 脚本在 Lambda 上执行此操作,这将具有在源文件上传到 S3 时自动触发的好处。我不太熟悉 Python SDK (boto),但看起来 get_object将以 stream of bytes 形式返回原始文件的正文,然后您可以将其作为行进行迭代,将您想要的行数累积到每个输出文件中。
关于python - 将 S3 文件拆分为 1000 行的较小文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56139995/
我有一个数组列表: ArrayList allText = new ArrayList(); 其内容是这样的: [Alabama - Montgomery, Alaska - Juneau, Ariz
我有一个 timestamp 格式的开始和结束时间。我想将它们分成多个时间段,例如 1 小时。 $t1 = strtotime('2010-05-06 12:00:00'); $t2 = strtot
我需要将 span10 分成 3 列,但我无法将它们排列起来。我应该在 span10 中添加一个 span12 还是使用 offset 还是??
我有一个时间序列。我想从早上 8 点到第二天早上 7:59 分成 24 小时的区 block 。我知道如何按日期分组,但我尝试过使用 TimeGroupers 和 DateOffsets 处理这个 8
我收到“街道号码邮政编码城市”形式的地址(作为字符串)。我想要做的是将街道和号码与邮政编码和城市分开。通常你可以按空格分割。但有些街道名称中也有空格,例如:“Emile Van Ermengemlaa
我有一个用户列表。其中一些用户处于第一状态,而其他用户处于第二状态。所以我想要的是将这个列表显示为首先,它按排序顺序显示存在 = 1 的用户,然后按排序顺序显示存在 = 2 的用户。这里的排序是根据用
我感觉我搜索了整个网络,但找不到一种方法将不同高度的 div 很好地划分为 3 列,就像 http://www.ing.nl 上那样 headertekst headerteksttesth
Bootstrap 3 按钮下拉菜单出现问题。你可以在这里看到我的两个例子: http://www.bootply.com/W1dLusilMk http://www.bootply.com/GGBv
我在 php 中执行以下操作 foreach($QuestionAsekd as $k => $v){ $grp_name = $v['NAME']; $groupValues[$gr
我找到了一种用pandas解析html的绝妙方法。我的数据格式有点奇怪(见下文)。我想将这些数据拆分为 2 个单独的数据帧。 注意每个单元格如何由,分隔...是否有任何真正有效的方法来分割所有这些单元
HTML 看起来像这样,但我不允许对其进行更改。我只能编写 CSS 将其变成 2 列。 Povezave www.behance.net www.kiberpipa.org www.o
假设我有以下数据框“A” utilization utilization_billable service 1
我需要将 2 个文本框拉伸(stretch)到 100% 的浏览器宽度,以及一个提交按钮。所有三个都应该在一行中,我试图拉伸(stretch)它但它没有发生......有什么想法吗? 代码: .sea
我是一名优秀的程序员,十分优秀!