Reputation:
Im trying to make a simple command i can call in discord that lets me see how many files are in a directory, but for some reason my code keeps hitting the following error as soon as i run the command:
`Traceback (most recent call last):
File "/home/pi/MusicToaster/musicbot/bot.py", line 1995, in on_message
response = await handler(**handler_kwargs)
File "/home/pi/MusicToaster/musicbot/bot.py", line 1822, in cmd_audiocache
stdout=asyncio.subprocess.PIPE)
File "/usr/local/lib/python3.5/asyncio/subprocess.py", line 212, in create_subprocess_exec
stderr=stderr, **kwds)
File "/usr/local/lib/python3.5/asyncio/base_events.py", line 970, in subprocess_exec
bufsize, **kwargs)
File "/usr/local/lib/python3.5/asyncio/unix_events.py", line 184, in _make_subprocess_transport
**kwargs)
File "/usr/local/lib/python3.5/asyncio/base_subprocess.py", line 40, in __init__
stderr=stderr, bufsize=bufsize, **kwargs)
File "/usr/local/lib/python3.5/asyncio/unix_events.py", line 635, in _start
universal_newlines=False, bufsize=bufsize, **kwargs)
File "/usr/local/lib/python3.5/subprocess.py", line 950, in __init__
restore_signals, start_new_session)
File "/usr/local/lib/python3.5/subprocess.py", line 1540, in _execute_child
raise child_exception_type(errno_num, err_msg)
FileNotFoundError: [Errno 2] No such file or directory: 'find /home/pi/MusicToaster/audio_cache -type f | wc -l'`
Ive checked the command im running and i cant seam to find a reason as to why it would have an error, when i type it in manually i have no issue:
The value has increased because the bot that writes to that folder was writing was running while i was taking that screenshot
Here is the code for the command:
async def cmd_audiocache(self, channel):
await self.safe_send_message(channel, "hang on ill check :thinking:")
process = await asyncio.create_subprocess_exec(
'find /home/pi/MusicToaster/audio_cache -type f | wc -l',
stdout=asyncio.subprocess.PIPE)
stdout, stderr = await process.communicate()
file_count = stdout.decode().strip()
file_count = str(file_count)
file_count = file_count + " songs stored"
await self.safe_send_message(channel, file_count)
process = await asyncio.create_subprocess_exec(
'du /home/pi/MusicToaster/audio_cache -h',
stdout=asyncio.subprocess.PIPE)
stdout, stderr = await process.communicate()
file_size = stdout.decode().strip()
file_size = str(file_size)
file_size = "all songs total to" + file_size
await self.safe_send_message(channel, file_size)
Please excuse the messiness of that code, i dont tidy code until i know it works.
Upvotes: 2
Views: 2555
Reputation: 13425
Note the difference between create_subprocess_exec:
Create a subprocess from one or more string arguments [...] where the first string specifies the program to execute, and the remaining strings specify the program’s arguments.
Create a subprocess from cmd [...] using the platform’s “shell” syntax.
Example:
# Using exec
process = await asyncio.create_subprocess_exec('ls', '-l')
# Using shell
process = await asyncio.create_subprocess_shell('ls -l')
Upvotes: 12