
Recherche avancée
Autres articles (50)
-
Personnaliser en ajoutant son logo, sa bannière ou son image de fond
5 septembre 2013, parCertains thèmes prennent en compte trois éléments de personnalisation : l’ajout d’un logo ; l’ajout d’une bannière l’ajout d’une image de fond ;
-
MediaSPIP v0.2
21 juin 2013, parMediaSPIP 0.2 est la première version de MediaSPIP stable.
Sa date de sortie officielle est le 21 juin 2013 et est annoncée ici.
Le fichier zip ici présent contient uniquement les sources de MediaSPIP en version standalone.
Comme pour la version précédente, il est nécessaire d’installer manuellement l’ensemble des dépendances logicielles sur le serveur.
Si vous souhaitez utiliser cette archive pour une installation en mode ferme, il vous faudra également procéder à d’autres modifications (...) -
Mise à disposition des fichiers
14 avril 2011, parPar défaut, lors de son initialisation, MediaSPIP ne permet pas aux visiteurs de télécharger les fichiers qu’ils soient originaux ou le résultat de leur transformation ou encodage. Il permet uniquement de les visualiser.
Cependant, il est possible et facile d’autoriser les visiteurs à avoir accès à ces documents et ce sous différentes formes.
Tout cela se passe dans la page de configuration du squelette. Il vous faut aller dans l’espace d’administration du canal, et choisir dans la navigation (...)
Sur d’autres sites (6306)
-
Anomalie #2244 : association fichiers zip - nom fichier long - css privé
23 mars 2012, par cedric -#grml... c’est le word-wrap:break-word qui est pas appliqué chez toi, ou qui est pas pris en compte, ou qui fait rien sur ce cas là ? où alors un max-width manquant ? Parceque hein ça marchait au moment du patch... :(
-
ffmpeg : error while loading shared libraries : libvpx.so.6 : cannot open shared object file : No such file or directory
16 avril 2021, par PanosI am building a multi tool discord bot in Python rewrite.


So I decided to add music to it as well. When I completed the bot and tried it on my local pc it worked perfectly. However when I uploaded to Heroku I got some errors for ffmpeg.


Initially I thought Heroku is Linux based so I downloaded ffmpeg for Linux. Still didn't work. Then i added a apt buildpack and downloaded it that way. It worked however now a get a different error. It finds the ffmpeg but the song is not played and this is displayed in the console :




[ffmpeg : error while loading shared libraries : libvpx.so.6 : cannot
open shared object file : No such file or directory]




How can I resolve this issue ?


Here is the whole code :


import discord
from discord.ext import commands

import asyncio
import itertools
import sys
import traceback
from async_timeout import timeout
from functools import partial
from youtube_dl import YoutubeDL
import ctypes
import ctypes.util

@commands.Cog.listener()
async def on_ready(self):

 print("ctypes - Find opus:")
 a = ctypes.util.find_library('opus')
 print(a)
 
 print("Discord - Load Opus:")
 b = discord.opus.load_opus(a)
 print(b)
 
 print("Discord - Is loaded:")
 c = discord.opus.is_loaded()
 print(c)



ytdlopts = {
 'format': 'bestaudio/best',
 'outtmpl': 'downloads/%(extractor)s-%(id)s-%(title)s.%(ext)s',
 'restrictfilenames': True,
 'noplaylist': True,
 'nocheckcertificate': True,
 'ignoreerrors': False,
 'logtostderr': False,
 'quiet': True,
 'no_warnings': True,
 'default_search': 'auto',
 'source_address': '0.0.0.0'
}

ffmpegopts = {
 'before_options': '-nostdin',
 'options': '-vn'
}

ytdl = YoutubeDL(ytdlopts)


class VoiceConnectionError(commands.CommandError):


class InvalidVoiceChannel(VoiceConnectionError):



class YTDLSource(discord.PCMVolumeTransformer):

 def __init__(self, source, *, data, requester):
 super().__init__(source)
 self.requester = requester

 self.title = data.get('title')
 self.web_url = data.get('webpage_url')


 def __getitem__(self, item: str):
 return self.__getattribute__(item)

 @classmethod
 async def create_source(cls, ctx, search: str, *, loop, download=False):
 loop = loop or asyncio.get_event_loop()

 to_run = partial(ytdl.extract_info, url=search, download=download)
 data = await loop.run_in_executor(None, to_run)

 if 'entries' in data:
 data = data['entries'][0]

 await ctx.send(f'```ini\n[Added {data["title"]} to the Queue.]\n```')

 if download:
 source = ytdl.prepare_filename(data)
 else:
 return {'webpage_url': data['webpage_url'], 'requester': ctx.author, 'title': data['title']}

 return cls(discord.FFmpegPCMAudio(source), data=data, requester=ctx.author)

 @classmethod
 async def regather_stream(cls, data, *, loop):
 """Used for preparing a stream, instead of downloading.
 Since Youtube Streaming links expire."""
 loop = loop or asyncio.get_event_loop()
 requester = data['requester']

 to_run = partial(ytdl.extract_info, url=data['webpage_url'], download=False)
 data = await loop.run_in_executor(None, to_run)

 return cls(discord.FFmpegPCMAudio(data['url']), data=data, requester=requester)


class MusicPlayer(commands.Cog):

 __slots__ = ('bot', '_guild', '_channel', '_cog', 'queue', 'next', 'current', 'np', 'volume')

 def __init__(self, ctx):
 self.bot = ctx.bot
 self._guild = ctx.guild
 self._channel = ctx.channel
 self._cog = ctx.cog

 self.queue = asyncio.Queue()
 self.next = asyncio.Event()

 self.np = None
 self.volume = .5
 self.current = None

 ctx.bot.loop.create_task(self.player_loop())

 async def player_loop(self):
 """Our main player loop."""
 await self.bot.wait_until_ready()

 while not self.bot.is_closed():
 self.next.clear()

 try:
 source = await self.queue.get()
 except asyncio.TimeoutError:
 return self.destroy(self._guild)

 if not isinstance(source, YTDLSource):
 try:
 source = await YTDLSource.regather_stream(source, loop=self.bot.loop)
 except Exception as e:
 await self._channel.send(f'There was an error processing your song.\n'
 f'```css\n[{e}]\n```')
 continue

 source.volume = self.volume
 self.current = source

 self._guild.voice_client.play(source, after=lambda _: self.bot.loop.call_soon_threadsafe(self.next.set))
 self.np = await self._channel.send(f'**Now Playing:** `{source.title}` requested by '
 f'`{source.requester}`')
 await self.next.wait()

 source.cleanup()
 self.current = None

 try:
 await self.np.delete()
 except discord.HTTPException:
 pass

 def destroy(self, guild):
 """Disconnect and cleanup the player."""
 return self.bot.loop.create_task(self._cog.cleanup(guild))


class Music(commands.Cog):
 """Music related commands."""

 __slots__ = ('bot', 'players')

 def __init__(self, bot):
 self.bot = bot
 self.players = {}

 async def cleanup(self, guild):
 try:
 await guild.voice_client.disconnect()
 except AttributeError:
 pass

 try:
 del self.players[guild.id]
 except KeyError:
 pass

 async def __local_check(self, ctx):
 """A local check which applies to all commands in this cog."""
 if not ctx.guild:
 raise commands.NoPrivateMessage
 return True

 async def __error(self, ctx, error):
 """A local error handler for all errors arising from commands in this cog."""
 if isinstance(error, commands.NoPrivateMessage):
 try:
 return await ctx.send('This command can not be used in Private Messages.')
 except discord.HTTPException:
 pass
 elif isinstance(error, InvalidVoiceChannel):
 await ctx.send('Error connecting to Voice Channel. '
 'Please make sure you are in a valid channel or provide me with one')

 print('Ignoring exception in command {}:'.format(ctx.command), file=sys.stderr)
 traceback.print_exception(type(error), error, error.__traceback__, file=sys.stderr)

 def get_player(self, ctx):
 """Retrieve the guild player, or generate one."""
 try:
 player = self.players[ctx.guild.id]
 except KeyError:
 player = MusicPlayer(ctx)
 self.players[ctx.guild.id] = player

 return player

 @commands.command(name='connect', aliases=['join'])
 async def connect_(self, ctx):
 try:
 channel = ctx.author.voice.channel
 except AttributeError:
 raise InvalidVoiceChannel('No channel to join.')

 vc = ctx.voice_client

 if vc:
 if vc.channel.id == channel.id:
 return
 try:
 await vc.move_to(channel)
 except asyncio.TimeoutError:
 raise VoiceConnectionError(f'Moving to channel: <{channel}> timed out.')
 else:
 try:
 await channel.connect()
 except asyncio.TimeoutError:
 raise VoiceConnectionError(f'Connecting to channel: <{channel}> timed out.')

 await ctx.send(f'Connected to: **{channel}**', )

 @commands.command(name='play', aliases=['sing'])
 async def play_(self, ctx, *, search: str):
 await ctx.trigger_typing()

 vc = ctx.voice_client

 if not vc:
 await ctx.invoke(self.connect_)

 player = self.get_player(ctx)
 source = await YTDLSource.create_source(ctx, search, loop=self.bot.loop, download=False)

 await player.queue.put(source)

 @commands.command(name='pause')
 async def pause_(self, ctx):
 """Pause the currently playing song."""
 vc = ctx.voice_client

 if not vc or not vc.is_playing():
 return await ctx.send('I am not currently playing anything!')
 elif vc.is_paused():
 return

 vc.pause()
 await ctx.send(f'**`{ctx.author}`**: Paused the song!')

 @commands.command(name='resume')
 async def resume_(self, ctx):
 """Resume the currently paused song."""
 vc = ctx.voice_client

 if not vc or not vc.is_connected():
 return await ctx.send('I am not currently playing anything!', )
 elif not vc.is_paused():
 return

 vc.resume()
 await ctx.send(f'**`{ctx.author}`**: Resumed the song!')

 @commands.command(name='skip')
 async def skip_(self, ctx):
 """Skip the song."""
 vc = ctx.voice_client

 if not vc or not vc.is_connected():
 return await ctx.send('I am not currently playing anything!')

 if vc.is_paused():
 pass
 elif not vc.is_playing():
 return

 vc.stop()
 await ctx.send(f'**`{ctx.author}`**: Skipped the song!')

 @commands.command(name='queue', aliases=['q', 'playlist'])
 async def queue_info(self, ctx):
 """Retrieve a basic queue of upcoming songs."""
 vc = ctx.voice_client

 if not vc or not vc.is_connected():
 return await ctx.send('I am not currently connected to voice!')

 player = self.get_player(ctx)
 if player.queue.empty():
 return await ctx.send('There are currently no more queued songs.')

 upcoming = list(itertools.islice(player.queue._queue, 0, 5))

 fmt = '\n'.join(f'**`{_["title"]}`**' for _ in upcoming)
 embed = discord.Embed(title=f'Upcoming - Next {len(upcoming)}', description=fmt)

 await ctx.send(embed=embed)

 @commands.command(name='now_playing', aliases=['np', 'current', 'currentsong', 'playing'])
 async def now_playing_(self, ctx):
 """Display information about the currently playing song."""
 vc = ctx.voice_client

 if not vc or not vc.is_connected():
 return await ctx.send('I am not currently connected to voice!', )

 player = self.get_player(ctx)
 if not player.current:
 return await ctx.send('I am not currently playing anything!')

 try:
 await player.np.delete()
 except discord.HTTPException:
 pass

 player.np = await ctx.send(f'**Now Playing:** `{vc.source.title}` '
 f'requested by `{vc.source.requester}`')

 @commands.command(name='volume', aliases=['vol'])
 async def change_volume(self, ctx, *, vol: float):
 """Change the player volume.
 Parameters
 ------------
 volume: float or int [Required]
 The volume to set the player to in percentage. This must be between 1 and 100.
 """
 vc = ctx.voice_client

 if not vc or not vc.is_connected():
 return await ctx.send('I am not currently connected to voice!', )

 if not 0 < vol < 101:
 return await ctx.send('Please enter a value between 1 and 100.')

 player = self.get_player(ctx)

 if vc.source:
 vc.source.volume = vol / 100

 player.volume = vol / 100
 await ctx.send(f'**`{ctx.author}`**: Set the volume to **{vol}%**')

 @commands.command(name='stop', aliases=['leave'])
 async def stop_(self, ctx):
 vc = ctx.voice_client

 if not vc or not vc.is_connected():
 return await ctx.send('I am not currently playing anything!')

 await self.cleanup(ctx.guild)


def setup(client):
 client.add_cog(Music(client))



-
Getting 0Kb png file from mp4 file : FFmpeg
6 novembre 2017, par muskanI have problems with ffmpeg. I am trying to convert the mp4 file to png file and the output is always a file of size 0kb
The command is :
ffmpeg.exe -i InputFile.mp4 -ss 00:00:10.00 -s 315x210 -f image2 -vframes 1 OutputFile.pngHere is the log :
ffmpeg version N-66289-gb76d613 Copyright (c) 2000-2014 the FFmpeg developers
built on Sep 15 2014 22:02:10 with gcc 4.8.3 (GCC)
configuration: --enable-gpl --enable-version3 --disable-w32threads --enable-avisynth --enable-bzlib --enable-fontconfig --enable-frei0r --enable-gnutls --enable-iconv --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --enable-libfreetype --enable-libgme --enable-libgsm --enable-libilbc --enable-libmodplug --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-librtmp --enable-libschroedinger --enable-libsoxr --enable-libspeex --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvo-aacenc --enable-libvo-amrwbenc --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxavs --enable-libxvid --enable-decklink --enable-zlib
libavutil 54. 7.100 / 54. 7.100
libavcodec 56. 1.100 / 56. 1.100
libavformat 56. 4.101 / 56. 4.101
libavdevice 56. 0.100 / 56. 0.100
libavfilter 5. 1.100 / 5. 1.100
libswscale 3. 0.100 / 3. 0.100
libswresample 1. 1.100 / 1. 1.100
libpostproc 53. 0.100 / 53. 0.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'InputFile.mp4':
Metadata:
major_brand : isom
minor_version : 512
compatible_brands: isomiso2avc1mp41
encoder : Lavf55.9.100
Duration: 00:00:49.70, start: 0.000000, bitrate: 491 kb/s
Stream #0:0(und): Video: h264 (Main) (avc1 / 0x31637661), yuv420p, 1280x720, 434 kb/s, 30 fps, 30 tbr, 90k tbn, 60 tbc (default)
Metadata:
handler_name : VideoHandler
Stream #0:1(und): Audio: aac (mp4a / 0x6134706D), 48000 Hz, mono, fltp, 48 kb/s (default)
Metadata:
handler_name : SoundHandler
Output #0, image2, to 'OutputFile.png':
Metadata:
major_brand : isom
minor_version : 512
compatible_brands: isomiso2avc1mp41
encoder : Lavf56.4.101
Stream #0:0(und): Video: png, rgb24, 315x210, q=2-31, 200 kb/s, 30 fps, 30 tbn, 30 tbc (default)
Metadata:
handler_name : VideoHandler
encoder : Lavc56.1.100 png
Stream mapping:
Stream #0:0 -> #0:0 (h264 (native) -> png (native))
Press [q] to stop, [?] for help
frame= 1 fps=0.0 q=0.0 Lsize=N/A time=00:00:00.03 bitrate=N/A
video:98kB audio:0kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: unknown