Schrift
[thread]8147[/thread]

Fehler beim Perlscript !: Das Script läuft nicht!



<< |< 1 2 3 >| >> 29 Einträge, 3 Seiten
Gast Gast
 2006-07-06 17:46
#67923 #67923
ich habe gerade mein 2tes script programmiert. leider funktioniert es nicht. kann mir jemand helfen.
Code: (dl )
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
#Der MySQL-Code:
#create database Mitarbeiter;
#use Mitarbeiter;
#create table Mitarbeiter(
#ID integer not null auto_increment,
#Nachname varchar(45),
#vorname varchar(45),
#Telefon integer,
#Kuerzel varchar(10),
#KST integer,
#Mail varchar(45),
#Buero varchar(10)
#primary key (ID));

################################################################################

#Initialisierung

print "Telefonliste\n\n";
use strict;
use DBI;
$option = 1;
$auswahl = 1;

################################################################################

#Hauptmenue

while ($option != 0){
print "Bitte waehlen Sie eine Option: \n";
print "1 Person eingeben \n";
print "2 Person suchen \n";
print "3 Person loeschen \n";
print "0 Beenden \n";
print "\nIhre Wahl: ";
$option = <STDIN>;
print "\n";

################################################################################

#Person eingeben

if ($option == 1){
print "\nBitte geben Sie den Nachnamen ein. \n";
my $nachname = <STDIN>;
print "\nBitte geben Sie den Vornamen ein. \n";
my $vorname = <STDIN>;
print "\nBitte geben Sie die interne Telefonnummer ein. \n";
my $tel = <STDIN>;
print "\nBitte geben Sie den Kuerzel ein. \n";
my $kuerzel = <STDIN>;
print "\nBitte geben Sie die Kostenstelle ein. \n";
my $kst = <STDIN>;
print "\nBitte geben Sie die E-Mail ein. \n";
my $mail = <STDIN>;
print "\nBitte geben Sie die Bueronummer ein. \n";
my $buero = <STDIN>;
print "\n\n";
my $database = "Mitarbeiter";
my $hostname = "localhost";
my $dsn = "DBI:mysql:database=$database;host=$hostname;
my $user = "root"; my $pass = "12345";
my $insert = qq(insert into Mitarbeiter values(null, $nachname, $vorname, $tel, $kuerzel, $kst, $mail, $buero);
my $dbh->disconnect;
};

################################################################################

#Person auslesen

if ($option == 2){

################################################################################

#Menue Suchen_nach

while ($auswahl != 0){
print "1 Suchen nach Nachname \n";
print "2 Suchen nach Vorname \n";
print "3 Suchen nach Telefonnummer \n";
print "4 Suchen nach Kuerzel \n";
print "5 Suchen nach Kostenstelle \n";
print "6 Suchen nach E-Mail \n";
print "7 Suchen nach Buero \n";
print "0 Hauptmenue \n";
print "\nIhre Wahl: ";
$auswahl = <STDIN>;

################################################################################

#Nach Nachnamen suchen

if ($auswahl == 1){

print "\nBitte geben Sie den Nachnamen ein. \n";

my $search = <STDIN>;

my $database = "Mitarbeiter";

my $hostname = "localhost";

my $dsn = "DBI:mysql:database=$database;host=$hostname;

my $user = "root"; my $pass = "12345";

my $result = qq(select * from Mitarbeiter where Nachname == $search);

my $dbh->disconnect;
};

################################################################################

#Nach Vornamen suchen

if ($auswahl == 2){

print "\nBitte geben Sie den Vornamen ein. \n";

my $search = <STDIN>;

my $database = "Mitarbeiter";

my $hostname = "localhost";

my $dsn = "DBI:mysql:database=$database;host=$hostname;

my $user = "root"; my $pass = "12345";

my $result = qq(select * from Mitarbeiter where Vorname == $search);

my $dbh->disconnect;
};

################################################################################

#Nach Telefonnummer suchen

if ($auswahl == 3){

print "\nBitte geben Sie die Telefonnummer ein. \n";

my $search = <STDIN>;

my $database = "Mitarbeiter";

my $hostname = "localhost";

my $dsn = "DBI:mysql:database=$database;host=$hostname;

my $user = "root"; my $pass = "12345";

my $result = qq(select * from Mitarbeiter where Telefon == $search);

my $dbh->disconnect;
};

################################################################################

#Nach Kuerzel suchen

if ($auswahl == 4){

print "\nBitte geben Sie den Kuerzel ein. \n";

my $search = <STDIN>;

my $database = "Mitarbeiter";

my $hostname = "localhost";

my $dsn = "DBI:mysql:database=$database;host=$hostname;

my $user = "root"; my $pass = "12345";

my $result = qq(select * from Mitarbeiter where Kuerzel == $search);

my $dbh->disconnect;
};

################################################################################

#Nach Kostenstelle suchen

if ($auswahl == 5){

print "\nBitte geben Sie die Kostenstelle ein. \n";

my $search = <STDIN>;

my $database = "Mitarbeiter";

my $hostname = "localhost";

my $dsn = "DBI:mysql:database=$database;host=$hostname;

my $user = "root"; my $pass = "12345";

my $result = qq(select * from Mitarbeiter where KST == $search);

my $dbh->disconnect;
};

################################################################################

#Nach E-Mail suchen

if ($auswahl == 6){

print "\nBitte geben Sie die E-Mail ein. \n";

my $search = <STDIN>;

my $database = "Mitarbeiter";

my $hostname = "localhost";

my $dsn = "DBI:mysql:database=$database;host=$hostname;

my $user = "root"; my $pass = "12345";

my $result = qq(select * from Mitarbeiter where Mail == $search);

my $dbh->disconnect;
};

################################################################################

#Nach Buero suchen

if ($auswahl == 7){

print "\nBitte geben Sie das Buero ein. \n";

my $search = <STDIN>;

my $database = "Mitarbeiter";

my $hostname = "localhost";

my $dsn = "DBI:mysql:database=$database;host=$hostname;

my $user = "root"; my $pass = "12345";

my $result = qq(select * from Mitarbeiter where Buero == $search);

my $dbh->disconnect;
};
};
};

################################################################################

#Person loeschen

if ($option == 3){
print "\nBitte geben Sie die ID ein. \n";
my $search = <STDIN>;
my $database = "Mitarbeiter";
my $hostname = "localhost";
my $dsn = "DBI:mysql:database=$database;host=$hostname;
my $user = "root"; my $pass = "12345";
my $loesche = qq(delete * from Mitarbeiter where ID == $search);
my $dbh->disconnect;
};

################################################################################

#Abschluss

};

################################################################################

#Copyright

print "\n© by Rafael Pedrett besitzer@betriebsdirektor.de";
\n\n

<!--EDIT|renee|1152193873-->
renee
 2006-07-06 17:58
#67924 #67924
User since
2003-08-04
14371 Artikel
ModeratorIn
[Homepage] [default_avatar]
Was sagt denn die Fehlermeldung?? Wahrscheinlich etwas wie Global symbol "$option" requires explicit package name, oder?? Du hast das my vergessen... Am besten liest Du Dir mal Wiki:den Wiki-Artikel durch.

Dann noch ein paar allgemeine Hinweise:

Am besten machst Du die Datenbankverbindung am Anfang auf. Dann hast den Code nicht an 10 verschiedenen Stellen im Skript.

Anstatt immer wieder ifs zu verwenden solltest Du elsif verwenden. Sonst wird jede einzelne Abfrage überprüft - ist aber unnötig, da die Auswahl nicht 2 und gleichzeitig 6 sein kann...

Du solltest Deinen Code zur besseren Lesbarkeit etwas anders einrücken. Also nicht
Code: (dl )
1
2
3
    if($bedingung){
$zeile = 1;
}


sondern besser so:
Code: (dl )
1
2
3
if($bedingung){
$zeile = 1;
}


Mir fällt gerade auf, dass Du nie die Verbindung zur Datenbank herstellst. Das solltest Du vielleicht mal machen...
OTRS-Erweiterungen (http://feature-addons.de/)
Frankfurt Perlmongers (http://frankfurt.pm/)
--

Unterlagen OTRS-Workshop 2012: http://otrs.perl-services.de/workshop.html
Perl-Entwicklung: http://perl-services.de/
nepos
 2006-07-06 18:39
#67925 #67925
User since
2005-08-17
1420 Artikel
BenutzerIn
[Homepage] [default_avatar]
Fuers Formatieren von Code koenntest du dir auch mal perltidy angucken, das hilft einem da ein wenig...
Rafael
 2006-07-26 10:11
#67926 #67926
User since
2006-07-26
22 Artikel
BenutzerIn
[default_avatar]
[quote=renee,06.07.2006, 15:58]1. Du solltest Deinen Code zur besseren Lesbarkeit etwas anders
einrücken.

2. Mir fällt gerade auf, dass Du nie die Verbindung zur Datenbank
herstellst. Das solltest Du vielleicht mal machen...[/quote]
1. Im Original ist is strukturiert.

2. Wie kann ich eine Verbindung herstellen?

Ich bin leider ein blutiger Anfänger
renee
 2006-07-26 10:23
#67927 #67927
User since
2003-08-04
14371 Artikel
ModeratorIn
[Homepage] [default_avatar]
Vielleicht liest Du Dir mal http://perl.renee-baecker.de/perl_datenbanken.pdf durch!
OTRS-Erweiterungen (http://feature-addons.de/)
Frankfurt Perlmongers (http://frankfurt.pm/)
--

Unterlagen OTRS-Workshop 2012: http://otrs.perl-services.de/workshop.html
Perl-Entwicklung: http://perl-services.de/
Rafael
 2006-07-26 10:46
#67928 #67928
User since
2006-07-26
22 Artikel
BenutzerIn
[default_avatar]
danke!
du kennst nicht zufällig einen guten Webspace-Anbieter, der Perl unterstützt?
kanns ja nicht auf der Kommandozeile testen!
renee
 2006-07-26 11:00
#67929 #67929
User since
2003-08-04
14371 Artikel
ModeratorIn
[Homepage] [default_avatar]
Wieso kannst Du es nicht auf der Kommandozeile testen??
OTRS-Erweiterungen (http://feature-addons.de/)
Frankfurt Perlmongers (http://frankfurt.pm/)
--

Unterlagen OTRS-Workshop 2012: http://otrs.perl-services.de/workshop.html
Perl-Entwicklung: http://perl-services.de/
Rafael
 2006-07-26 11:04
#67930 #67930
User since
2006-07-26
22 Artikel
BenutzerIn
[default_avatar]
DBI noch nicht installiert
Rafael
 2006-07-26 11:19
#67931 #67931
User since
2006-07-26
22 Artikel
BenutzerIn
[default_avatar]
ok habs jetzt installiert!

hab jetzt aber das nächste Problem!
wie kann man ein @ anzeigen?
styx-cc
 2006-07-26 11:29
#67932 #67932
User since
2006-05-20
533 Artikel
BenutzerIn

user image
hm, ich hoffe ich hab verstanden was du willst:
So:
Code: (dl )
print '@';

oder so:
Code: (dl )
print "\@";

oder, oder..

MfG

edit: bestimmte Zeichen muss man maskieren:
http://de.selfhtml.org/perl....elfHTML\n\n

<!--EDIT|styx-cc|1153899285-->
Pörl.
<< |< 1 2 3 >| >> 29 Einträge, 3 Seiten



View all threads created 2006-07-06 17:46.