人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動態(tài)

Python自動化短視頻生成腳本實現(xiàn)熱門視頻流水線生產(chǎn)

發(fā)布日期:2021-12-31 09:34 | 文章來源:站長之家

一、核心功能設計

首先我看了網(wǎng)上那些視頻營銷號的視頻,大多數(shù)都是圍繞一個主題通過幾張圖片進行視頻輪播展示并添加一些熱門歌曲作為背景音樂。

知道了大概的思路,接下來我們可以通過以下幾步進行實現(xiàn):

  • 通過關鍵字進行圖片批量爬取
  • 對爬取的圖片進行篩選并批量進行大小resize統(tǒng)一
  • 將統(tǒng)一大小的圖片進行視頻合成
  • 根據(jù)選取的歌曲,截取合適的背景音樂
  • 將視頻和截取的背景音樂合并

二、實現(xiàn)步驟

1. 圖片爬取

當然如果小伙伴已經(jīng)有視頻素材了,只想給視頻直接添加背景可以直接跳到第四步;如果已經(jīng)有圖片素材不需要爬取了,可以直接跳到第二步。

第一步,我們可以根據(jù)需要的視頻主題進行關鍵字圖片搜索,對圖片進行批量爬取。例如我們以日本動漫《你的名字》作為主題,通過輸入關鍵字,爬取動漫相關的圖片。核心代碼如下:

def dowmloadimg(html, keyword, startNum):
 headers = {'user-agent': 'Mozilla/5.0'}  # 請求頭
 pic_url = re.findall('"objURL":"(.*?)",', html, re.S)  # 找到符合正則規(guī)則的網(wǎng)址
 num = len(pic_url)
 i = startNum
 subroot = root
 txtpath = subroot + '/download_img.txt'
 print('找到關鍵詞:' + keyword + '的圖片,開始下載圖片...')
 for each in pic_url:
  a = '第' + str(i + 1) + '張圖片,圖片地址:' + str(each) + '\n'
  b = '正在下載' + a
  print(b)
  path = subroot + '/' + str(i + 1)
  try:
if not os.path.exists(subroot):
 os.makedirs(subroot)
if not os.path.exists(path):
 pic = requests.get(each, headers=headers, timeout=10)
 with open(path + '.jpg', 'wb') as f:
  f.write(pic.content)
  f.close()
 with open(txtpath, 'a') as f:
  f.write(a)
  f.close()
  except:
traceback.print_exc()
print('ERROR?。?!當前圖片無法下載!?。?)
continue
  i += 1
 return i
words = input("請輸入關鍵字: ")
root = './' + words
if not os.path.exists(root):
 os.makedirs(root)
# 參數(shù)為需爬取的頁數(shù)
for i in range(2):
 url = 'http://image.baidu.com/search/flip?tn=baiduimage&ie=utf-8&word=' + words + "&pn=" + str(
  pageId) + "&gsm=?&ct=&ic=0&lm=-1&width=0&height=0"
 pageId += 20
 html = requests.get(url, headers=headers)
 lastNum = dowmloadimg(html.text, words, lastNum, )  # 執(zhí)行一次獲取60張圖

至此我們就可以根據(jù)關鍵字將圖片爬取下來,并將圖片根據(jù)數(shù)字順序命名,如下圖所示。

2. 圖片統(tǒng)一格式大小

第二步,我們需要將獲取的圖片進行大小格式統(tǒng)一,方便后面的視頻合成。這里我們可以自己手動篩選部分需要resize統(tǒng)一大小的圖片,也可以對爬取的整個文件夾下圖片批量統(tǒng)一格式大小。對于圖片大小尺寸可以通過代碼進行設置,這里我們將所有圖片大小統(tǒng)一成600*800的。核心代碼如下:

# 將所有圖像resize成600*800,并保存
def resize_image(image_name):
 # 獲取輸入文件夾中的所有文件
 files = os.listdir('./' + image_name)
 output_dir = './resize/'
 # 判斷輸出文件夾是否存在,不存在則創(chuàng)建
 if not os.path.exists(output_dir):
  os.makedirs(output_dir)
 for file in files:
  if file[-4:] == ".jpg":
img = Image.open('./' + image_name + '/' + file)
# 將所有圖片均轉成RGB,防止圖片格式異常
img = img.convert('RGB')
# resize圖片大小設置成600*800
img = img.resize((600, 800), Image.ANTIALIAS)
img.save(os.path.join(output_dir, file))

3. 視頻合成

第三步,我們可以將這些格式大小統(tǒng)一的圖片進行視頻合成,這里我們可以把整個文件夾中的圖片全部合成,也可以自己手動選取部分。合成的時候我們根據(jù)圖片的數(shù)字命名順序進行一次合并,核心代碼如下:

def charts2video(img_path, video_path):
 """將給定目錄下的圖片轉成視頻
  img_path: 圖片路徑
  video_path: 輸出視頻的路徑名稱
 返回: 圖片轉成的視頻
 """
 images = os.listdir(img_path)
 images.sort(key=lambda x: int(x[:-4]))  # 以名稱字符串的數(shù)字從小到大排序  
 fps = 1.5  # 幀數(shù)
 fourcc = cv2.VideoWriter_fourcc('D', 'I', 'V', 'X')
 im = Image.open(img_path + images[0])
 video_writer = cv2.VideoWriter(video_path, fourcc, fps, im.size)
 for img_i in images:
  frame = cv2.imread(img_path + img_i)
  print('開始將 ' + img_i + ' 加入視頻\n')
  video_writer.write(frame)  # 圖片尺寸必須和視頻尺寸一樣,不然不會被加入視頻中?。。? video_writer.release()

這里如果我們要控制視頻每秒鐘播放的圖片張數(shù),可以根據(jù)fps代表的每一秒播放多少張圖片對幀數(shù)自行設置,從而完成圖片的視頻合成。

4. 截取背景音樂

第四步,在背景音樂截取前,我們首先需要確認視頻時長,這樣我們才能截取適時的背景音樂。所以我們可以先獲取視頻的長度,返回的就是以s為單位的視頻時長,核心代碼如下:

def get_video_time(filename):
  cap = cv2.VideoCapture(filename)
  if cap.isOpened():
 rate = cap.get(5)
 frame_num =cap.get(7)
 duration = frame_num/rate
 return duration
  return -1
t = get_video_duration('./你的名字.mp4')

視頻時長知道了,接下來我們就要進行背景音樂截取了,之前博主有寫過一篇文章

關于如何用Python自制一款炫酷音樂播放器,感興趣的可以去看看是如何制作的。

今天我們就使用這款自制的音樂播放器來下載我們需要的音樂。例如我們就以《錯位時空》作為背景音樂,我們可以先通過這款音樂播放器將這首歌下載到本地。如下圖所示。

音樂下載完畢,接下來就是音樂截取,這里我們提供了兩種方式。一種是截取歌曲高潮部分,另一種是自己選取歌曲截取區(qū)間。

歌曲高潮自動截?。?/p>

經(jīng)常刷短視頻的小伙伴,可以看到網(wǎng)上很多短視頻背景音樂都是歌曲的高潮部分。那么Python能否自動獲取歌曲的高潮部分呢?當然!Python已經(jīng)考慮到了,可以自動截取歌曲高潮部分,這里我們需要用到pychorus模塊,具體這個是如何實現(xiàn),大家可以網(wǎng)上查資料研究研究。

首先我們需要安裝下pychorus模塊

pip install pychorus

安裝完成后,導入pychorus模塊,一行代碼調(diào)用就可以實現(xiàn),這里傳入的參數(shù)t就是上面我們獲取的視頻時長,這樣可以確保截取的背景音樂和視頻時長一致,方便視頻和音樂合成。

同時我們還需要注意下,一般一首歌曲的時長大概3-4分鐘,所以我們傳入的t最好不要超過1分鐘,否則可能會出現(xiàn)高潮截取失敗。核心代碼如下:

from pychorus import find_and_output_chorus
chorus_start_sec = find_and_output_chorus("./錯位時空 - 艾辰.mp3", "./錯位時空_high.wav", t)

如下圖,我們知道了視頻的時長是26s,然后截取背景音樂,自動獲取的高潮部分是從2分32秒開始,時長26s。至此我們就可以把當前歌曲的高潮部分截取出來進行最后的視頻和音樂合并了。

自定義截取歌曲區(qū)間:

如果本身我們的視頻長度較長,截取不到歌曲高潮部分怎么辦呢?我們可以進行自己定義歌曲截取區(qū)間來獲取背景音樂,下面就演示下,截取歌曲從20s開始到90s結束,核心代碼如下:

# 截取背景音樂
audio_background = mpy.AudioFileClip('./錯位時空 - 艾辰.mp3').subclip(20, 90)
audio_background.write_audiofile('bk.mp3')

5. 視頻和背景音樂合并

第五步,我們需要把視頻和剛剛截取好的背景音樂進行合并,合成一個新的視頻,核心代碼如下:

def add_music():
 # 讀取代碼視頻
 my_clip = mpy.VideoFileClip('你的名字.mp4')
 # 截取背景音樂
 audio_background = mpy.AudioFileClip('錯位時空_high.wav')
 # 視頻中插入音頻
 final_clip = my_clip.set_audio(audio_background)
 # 保存最終視頻
 final_clip.write_videofile('result.mp4')

至此,整個視頻就可以自動生成,實現(xiàn)熱門視頻流水線生產(chǎn)了!下面我們一起運行下看看自動生成的視頻效果如何吧。

以上就是Python自動化短視頻生成腳本實現(xiàn)熱門視頻流水線生產(chǎn)的詳細內(nèi)容,更多關于Python自動化生成腳本的資料請關注本站其它相關文章!

版權聲明:本站文章來源標注為YINGSOO的內(nèi)容版權均為本站所有,歡迎引用、轉載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務器上建立鏡像,否則將依法追究法律責任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學習參考,不代表本站立場,如有內(nèi)容涉嫌侵權,請聯(lián)系alex-e#qq.com處理。

相關文章

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務

7x24全年不間斷在線

專屬顧問服務

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務熱線

關注
微信

關注官方微信
頂部