Rechercher : dans
Par :

[Shell Unix] Convertir du Batch en Shell Unix

Dernière réponse le 11 jun 2009 à 10:53:20 Trezeg, le 15 jan 2007 à 17:19:51 
 Signaler ce message aux modérateurs

Bonjour à tous,

J'aimerais traduire la ligne de Batch suivante en Shell Unix mais je galère :-(

set CMD_LINE=for /F "delims=. tokens=1,2,3,4,5,6" %%i in ('type %SQL4OUT_PROC_ROOT%%PAR4OUT_FILE%%PAR_EXT%') do sqlplus %vORA_USR%/%vORA_PWD%@%vORA_SRV% @%SQL_OUT_LIB_ROOT%%%i%BS%%%l%SQL_EXT% '"%%m.%%n"' '"%%k"' '"%DATA_BS_ROOT%%%i%BS%%%k%BS%%%l%BS%%WRK_DIR%%BS%Retour%%m%CSV_EXT%' '"%DATA_BS_ROOT%%%i%BS%%%k%BS%%%l%BS%%WRK_DIR%%BS%%%m%CSV_EXT%' '"%%l"' '"%vORA_SRV%"' '"%vORA_USR%"' '"%vORA_PWD%"'

Quelqu'un peut-il éclairer ma lanterne ?

Merci

Trez

Configuration: Windows NT 4.0
Internet Explorer 5.5

Meilleures réponses pour « [Shell Unix] Convertir du Batch en Shell Unix » dans :
Sed - Conversion retours chariots DOS (CRLF) / UNIX (LF) VoirConversion format de fichier DOS UNIX / UNIX DOS Préambule Ce qu'il faut savoir Conversion DOS vers UNIX Conversion UNIX vers DOS Préambule Il existe déjà des utilitaires (dos2unix et unix2dos) qui s'acquittent très bien ce...
Exécuter un script shell VoirExécution d'un script Pour pouvoir exécuter un script ou un programme en ligne de commande il y a plusieurs possibilités : 1. Le chemin absolu 2. Le chemin relatif 3. Modifier la variable PATH Note: Le Sha...
Télécharger CygWin VoirCygwin est un environnement UNIX pour Windows composé: d'un shell Unix d'une librairie dynamique (DLL) chargée de fournir une couche d'émulation Unix pour le système Windows d'un ensemble de librairies, sources et exécutables adaptés à Cygwin...
Systèmes UNIX - Le shell VoirIntroduction au shell L'interpréteur de commandes est l'interface entre l'utilisateur et le système d'exploitation, d'où son nom anglais «shell», qui signifie «coquille». Le shell est ainsi chargé de faire l'intermédiaire entre le système...
Introduction aux systèmes UNIX VoirLe système UNIX Le système Unix est un système d'exploitation multi-utilisateurs, multi-tâches, ce qui signifie qu'il permet à un ordinateur mono ou multi-processeurs de faire exécuter simultanément plusieurs programmes par un ou plusieurs...

1

mamiemando, le 15 jan 2007 à 20:43:14

Ben explique nous déjà ce que fait ton script batch, et surtout fais les retour à la ligne dans ton code et indente le. Puis mets les balises codes

< code > ... < /code >

Cf le bouton code au dessus de la boite dans laquelle tu tapes ton texte pour poster un message...

Bonne chance

Répondre à mamiemando

2

Trezeg, le 16 jan 2007 à 22:41:43

Ok je reprends ;)

La ligne de commande a pour but d'initialiser la variable CMD_LINE avec un chemin qui est découpé par le "delims". Un sqlplus est ensuite appelé avec les paramètres de user, password et serveur. La commande est complétée par les paramètres initiaux du "delims" (%%i , %%l, %%k etc...).
Plus proprement ca nous donne :

set CMD_LINE=for /F "delims=. tokens=1,2,3,4,5,6" %%i in ('type %SQL4OUT_PROC_ROOT%%PAR4OUT_FILE%%PAR_EXT%')
do sqlplus %vORA_USR%/%vORA_PWD%@%vORA_SRV% @%SQL_OUT_LIB_ROOT%%%i%BS%%%l%SQL_EXT%
'"%%m.%%n"' '"%%k"' '"%DATA_BS_ROOT%%%i%BS%%%k%BS%%%l%BS%%WRK_DIR%%BS%Retour%%m%CSV_EXT%' '"%DATA_BS_ROOT%
%%i%BS%%%k%BS%%%l%BS%%WRK_DIR%%BS%%%m%CSV_EXT%' '"%%l"'

ps : j'ai supprimé les 3 derniers parametres vORA_PWD, vORA_SRV et vORA_USR car ils sont deja appelé au début du "do sqlplus"

Merci pour votre aide.

Trez

Répondre à Trezeg

3

mamiemando, le 17 jan 2007 à 02:30:11

J'ai pas de shell sous la main mais à mon avis un truc du genre pourrait marcher

#!/bin/sh
PATH="/home/mando/plop"
DELIM="."
PATH2= `echo ${PATH}| sed -nre "s/${DELIM}/  /g"`
for x in `echo ${PATH2}`
do
  echo $x
done

Je te laisse enchaîner car je ne comprends rien à la syntaxe batch :-)
En plus sans rien pour tester ce que je fais c'est chaud c'est juste pour te donner l'idée.

Bonne chance

Répondre à mamiemando

4

Trezeg, le 17 jan 2007 à 10:18:55

Merci Mamiemando ;-)
Je testerais le truc un peu plus tard...
Par contre voici quelques précisions permettant de mieux comprendre le batch.

set SQL4OUT_PROC_ROOT=PROJ\ITF\PROD\PROC\SQL4OUT
set BS=\
set PAR4OUT_FILE=par4out
set PAR_EXT=.par
set WRK_DIR=PourTransmettre
set DATA_BS_ROOT=PROJ\ITF\PROD\DATA
set CSV_EXT=.ext
Merci pour votre aide

Répondre à Trezeg

5

mamiemando, le 17 jan 2007 à 19:31:18

En fait pour que je t'aide plus il faudrait me dire quels sont les paramètres de ton programme, leur format, et ce que tu veux obtenir en sortie.

Bonne chance

Répondre à mamiemando

6

Trezeg, le 18 jan 2007 à 09:03:35

Bonjour,

Cet exercice n'est plus d'actualité (le source en batch a été modifié par le prof)... Donc pas la peine de se faire des ch'veux blancs avec ;-p

Trez

Répondre à Trezeg

7

 Trezeg, le 18 jan 2007 à 11:27:08

Oupss j'oubliais,

Merci beaucoup Mamiemando ;-)

Trez

Répondre à Trezeg