Название: QProcess и консольное приложение Отправлено: Ilya_181 от Март 18, 2018, 15:39 Может кто-то помочь? Почему не работает? Консольная программа (sox) должна объединить два трека, через cmd вручную проверял - работает, однако написанный код не работает.
Код
Название: Re: QProcess и консольное приложение Отправлено: qate от Март 19, 2018, 13:17 QString programm = qApp->applicationDirPath() + QString("/sox/sox.exe");
process.start("cmd", QStringList() << "/C" << programm << "track01.wav track02.wav result.wav"); Название: Re: QProcess и консольное приложение Отправлено: Kurles от Март 22, 2018, 14:28 Может кто-то помочь? Почему не работает? Консольная программа (sox) должна объединить два трека, через cmd вручную проверял - работает, однако написанный код не работает. Мне кажется дело может быть в этом:Код
Код надо так: Код
Название: Re: QProcess и консольное приложение Отправлено: Alex Custov от Март 22, 2018, 14:57 Код: strListKey << "track01.wav track02.wav result.wav"; Здесь ты создаёшь ОДИН аргумент для sox. И он пытается открыть файл "track01.wav track02.wav result.wav". Выше написано как правильно. Название: Re: QProcess и консольное приложение Отправлено: Ilya_181 от Апрель 18, 2018, 18:58 Код Так тоже не работает. Пытался сделать как ниже. Выдает ошибку. Код Ошибка в консоли: QWindowsPipeWriter::write failed. (Идет закрытие канала.) Text "D:\\\\Programing\\\\Sox\\\\sox.exe: SoX v14.4.2\r\n\r\nUsage summary: [gopts] [[fopts] infile]... [fopts] outfile [effect [effopt]]...\r\n\r\nSPECIAL FILENAMES (infile, outfile):\r\n- Pipe/redirect input/output (stdin/stdout); may need -t\r\n-d, --default-device Use the default audio device (where available)\r\n-n, --null Use the `null' file handler; e.g. with synth effect\r\n-p, --sox-pipe Alias for `-t sox -'\r\n\r\nSPECIAL FILENAMES (infile only):\r\n\"|program [options] ...\" Pipe input from external program (where supported)\r\nhttp://server/file Use the given URL as input file (where supported)\r\n\r\nGLOBAL OPTIONS (gopts) (can be specified at any point before the first effect):\r\n--buffer BYTES Set the size of all processing buffers (default 8192)\r\n--clobber Don't prompt to overwrite output file (default)\r\n--combine concatenate Concatenate all input files (default for sox, rec)\r\n--combine sequence Sequence all input files (default for play)\r\n-D, --no-dither Don't dither automatically\r\n--dft-min NUM Minimum size (log2) for DFT processing (default 10)\r\n--effects-file FILENAME File containing effects and options\r\n-G, --guard Use temporary files to guard against clipping\r\n-h, --help Display version number and usage information\r\n--help-effect NAME Show usage of effect NAME, or NAME=all for all\r\n--help-format NAME Show info on format NAME, or NAME=all for all\r\n--i, --info Behave as soxi(1)\r\n--input-buffer BYTES Override the input buffer size (default: as --buffer)\r\n--no-clobber Prompt to overwrite output file\r\n-m, --combine mix Mix multiple input files (instead of concatenating)\r\n--combine mix-power Mix to equal power (instead of concatenating)\r\n-M, --combine merge Merge multiple input files (instead of concatenating)\r\n--multi-threaded Enable parallel effects channels processing\r\n--norm Guard (see --guard) & normalise\r\n--play-rate-arg ARG Default `rate' argument for auto-resample with `play'\r\n--plot gnuplot|octave Generate script to plot response of filter effect\r\n-q, --no-show-progress Run in quiet mode; opposite of -S\r\n--replay-gain track|album|off Default: off (sox, rec), track (play)\r\n-R Use default random numbers (same on each run of SoX)\r\n-S, --show-progress Display progress while processing audio data\r\n--single-threaded Disable parallel effects channels processing\r\n--temp DIRECTORY Specify the directory to use for temporary files\r\n-T, --combine multiply Multiply samples of corresponding channels from all\r\n input files (instead of concatenating)\r\n--version Display version number of SoX and exit\r\n-V[LEVEL] Increment or set verbosity level (default 2); levels:\r\n 1: failure messages\r\n 2: warnings\r\n 3: details of processing\r\n 4-6: increasing levels of debug messages\r\nFORMAT OPTIONS (fopts):\r\nInput file format options need only be supplied for files that are headerless.\r\nOutput files will have the same format as the input file where possible and not\r\noverridden by any of various means including providing output format options.\r\n\r\n-v|--volume FACTOR Input file volume adjustment factor (real number)\r\n--ignore-length Ignore input file length given in header; read to EOF\r\n-t|--type FILETYPE File type of audio\r\n-e|--encoding ENCODING Set encoding (ENCODING may be one of signed-integer,\r\n unsigned-integer, floating-point, mu-law, a-law,\r\n ima-adpcm, ms-adpcm, gsm-full-rate)\r\n-b|--bits BITS Encoded sample size in bits\r\n-N|--reverse-nibbles Encoded nibble-order\r\n-X|--reverse-bits Encoded bit-order\r\n--endian little|big|swap Encoded byte-order; swap means opposite to default\r\n-L/-B/-x Short options for the above\r\n-c|--channels CHANNELS Number of channels of audio data; e.g. 2 = stereo\r\n-r|--rate RATE Sample rate of audio\r\n-C|--compression FACTOR Compression factor for output format\r\n--add-comment TEXT Append output file comment\r\n--comment TEXT Specify comment text for the output file\r\n--comment-file FILENAME File containing comment text for the output file\r\n--no-glob Don't `glob' wildcard match the following filename\r\n\r\nAUDIO FILE FORMATS: 8svx aif aifc aiff aiffc al amb amr-nb amr-wb anb au avr awb cdda cdr cvs cvsd cvu dat dvms f32 f4 f64 f8 flac fssd gsm gsrt hcom htk ima ircam la lpc lpc10 lu maud mp2 mp3 nist ogg prc raw s1 s16 s2 s24 s3 s32 s4 s8 sb sf sl sln smp snd sndr sndt sou sox sph sw txw u1 u16 u2 u24 u3 u32 u4 u8 ub ul uw vms voc vorbis vox wav wavpcm wv wve xa\r\nPLAYLIST FORMATS: m3u pls\r\nAUDIO DEVICE DRIVERS: waveaudio\r\n\r\nEFFECTS: allpass band bandpass bandreject bass bend biquad chorus channels compand contrast dcshift deemph delay dither divide+ downsample earwax echo echos equalizer fade fir firfit+ flanger gain highpass hilbert input# ladspa loudness lowpass mcompand noiseprof noisered norm oops output# overdrive pad phaser pitch rate remix repeat reverb reverse riaa silence sinc spectrogram speed splice stat stats stretch swap synth tempo treble tremolo trim upsample vad vol\r\n * Deprecated effect + Experimental effect # LibSoX-only effect\r\nEFFECT OPTIONS (effopts): effect dependent; see --help-effect\r\n" Помогите кто-то. Так и не могу понять. Через консоль все работает, а через QProcess не работает. Название: Re: QProcess и консольное приложение Отправлено: kambala от Апрель 18, 2018, 22:21 ну так выложи минимальный проект или хотя бы эту программу sox.exe
в твоем последнем коде написано точно неправильно Название: Re: QProcess и консольное приложение Отправлено: Ilya_181 от Апрель 22, 2018, 08:18 Код
Помогите пожалуйста. Через консоль пробовал все работает. Название: Re: QProcess и консольное приложение Отправлено: Kurles от Апрель 22, 2018, 09:17 Код
Помогите пожалуйста. Через консоль пробовал все работает. Название: Re: QProcess и консольное приложение Отправлено: Ilya_181 от Апрель 23, 2018, 21:31 Цитировать А где твои wav файлы находятся? Попробуй указать полные пути до них. Код
Название: Re: QProcess и консольное приложение Отправлено: Alex Custov от Апрель 23, 2018, 22:52 Цитировать Я уже говорил тебе,что такое безумие,а? Безумие - это точное повторение одного и того же действия. Раз за разом, в надежде на изменение. Налицо полное непонимание того, что ты делаешь: 1) скармливаешь сразу все файлы одной строкой для QProcess::start(). Процесс sox, как я уже писал, попытается открыть файл с именем "track01.wav track02.wav Sometrack03.wav", которого естественно нет, и проваливается 2) пытаешься писать в stdin этого процесса с помощью QProcess::write(), хотя sox поддерживает режим записи через stdin совсем по-другому, через спецификацию "-" файла, о чём написано в хелпе -h. Естественно, это не работает 3) скармливаешь Qt-шные пути "D://FolderSox//sox_14_4_2//track01.wav" программе прямо в stdin, хотя она явно не в курсе что такое "//" Предвижу вопрос типа хватит умничать, просто напиши решение. Пожалуйста, думаю смысл понятен: Код
Входные файлы - два виндовых wav звука на моём диске F. Выход - result.wav также на моём диске F. Это всё ещё можно сократить ещё больше через QProcess::execute(). Название: Re: QProcess и консольное приложение Отправлено: Ilya_181 от Апрель 25, 2018, 20:58 Код Alex Custov спасибо большое. Это отлично работает. Мне жаль что вам пришлось прописывать весь код. Благодарю за терпение. |