小编Dig*_*eld的帖子

Amazon Athena 将位置设置为单个 csv 文件

我想将 Athena SQL 创建表语句中的位置值设置为单个 CSV 文件,因为我不想查询路径中的每个文件。我可以设置并成功查询 s3 目录(对象)路径以及该路径中的所有文件,但不能查询单个文件。是否支持将单个文件设置为位置?

成功查询路径中的 CSV 文件:

LOCATION 's3://my_bucket/path/'
Run Code Online (Sandbox Code Playgroud)

返回零结果:

LOCATION 's3://my_bucket/path/filename.csv.gz'
Run Code Online (Sandbox Code Playgroud)

建表语句:

CREATE EXTERNAL TABLE IF NOT EXISTS `default`.`my_db` (
    `name` string,
    `occupation` string,    
    )
    ROW FORMAT SERDE 'org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe' 
    WITH SERDEPROPERTIES (
    'field.delim' = ','
   ) LOCATION 's3://bucket-name/path/filename.csv.gz'
   TBLPROPERTIES ('has_encrypted_data'='false');
Run Code Online (Sandbox Code Playgroud)

我已阅读此问答,但它似乎没有解决同一问题。

谢谢。

sql csv amazon-s3 amazon-web-services amazon-athena

3
推荐指数
1
解决办法
1085
查看次数

将 Python 列表传递给 Moviepy 模块中的 concatenate_videoclips 函数

目的:

  1. 在目录中构建视频文件的python列表
  2. 打开视频剪辑(了解moviepy的要求)
  3. 调用 combine_clips 函数并传递“剪辑”列表(此处发生错误。)
  4. 将组合剪辑写入单个视频文件

错误:

"concatenate.py", line 71, in concatenate_videoclips
tt = np.cumsum([0] + [c.duration for c in clips])
AttributeError: 'str' object has no attribute 'duration'"
Run Code Online (Sandbox Code Playgroud)

脚本:

import os
from moviepy.editor import *

def clips_list():
    clips = []
    for file in os.listdir('.'):
        if file.endswith(".mov"):
            clips.append(file)
    open_clips(clips)

def open_clips(clips):
    for clip in clips:
        VideoFileClip(clip)
    combine_clips(clips)

def combine_clips(clips):
    video = concatenate_videoclips(clips, method='compose')

def output_video(video):
    video.write_videofile('ct_01.mp4')

clips_list()
Run Code Online (Sandbox Code Playgroud)

问题:为什么“concatenate_videoclips()”接受一个硬编码的列表,但是当我向它传递一个列表时却失败了。

python video moviepy

1
推荐指数
1
解决办法
2845
查看次数