我想将 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)
谢谢。
目的:
错误:
"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()”接受一个硬编码的列表,但是当我向它传递一个列表时却失败了。