FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
de listbox a tabla
hola, estoy realizando un sistema para colegios y tengo un modulo donde asigno las materias a cada grado. tengo un edit que me acepta el codigo del grado que voy a utilizar, y tengo un listbox1 con todas las materias que estan registradas. tengo otro listbox2 donde voy a pasar las materias del listbox1 que ese grado va a utilizar. ejemplo:
lo que deseo es grabar los datos del listbox2 en una tabla obteniendo el codigo del grado y grabarlo que que quede por ejemplo: materiaid ! descripcion -----------!----------------- 5 ! ciencias naturales 5 ! ciencias sociales 5 ! conducta 5 ! educ. artistica estoy usando el siguiente codigo pero no me funciona:::
necesito ver sus opiniones,,, espero que me hallan entendido,,, y gracias.... |
#2
|
||||
|
||||
Hola, no dices qué problema es el que te da pero en principio deberías de cambiar el "append" de sitio y ponerlo debajo del "for".
Saludos
__________________
Be water my friend. |
#3
|
|||
|
|||
hola newtron, el problema es que solamente me graba el primer items del listbox, y lo que quiero es que grabe el primero luego siga con los demas agregandole a cada uno el codigo del grado que esta en el edit.
|
#4
|
||||
|
||||
Hola, prueba así
Saludos |
#5
|
|||
|
|||
hola jafera, le hice los cambios pero aun asi solo me graba el primer item del listbox,, parece que el for no lo esta recorriendo
|
#6
|
||||
|
||||
Perdón, habia cogido el código de un uso mio que lo hago desde una tabla, tu lo que tienes que hacer es un next al item del listbox2
listsbox2.Items.Next; procedure TForm1.Button1Click(Sender: TObject);var a:integer; begin for a := 0 to listbox2.count -1 do begin dmdatos.ATMATERIAS.Append; // cambia de posición tal como dice newtron dmdatos.ATMATERIASMATERIAID.AsString:=edit1.Text; dmdatos.ATMATERIASDESCRIPCION.AsString:=listbox2.Items.Text; dmdatos.ATMATERIAS.Post; listbox2.Items.Next; // añade dmdatos.ATMATERIAS.Next; // quita end; A ver así Saludos |
#7
|
|||
|
|||
da error en la linea:
listbox2.items.next; creo que el next no se utiliza en el listbox |
#8
|
||||
|
||||
No se, puedes probar con ItemIdex.
listbox2.ItemIndex(a); Mira en la ayuda de Delphi (yo lo estoy haciendo) Josep Última edición por jafera fecha: 05-04-2012 a las 10:54:03. |
#9
|
|||
|
|||
Hola: debes indicarle el numero de indice del ListBox.
Nada mas que eso. Del bucle se encarga el for. Saludos |
#10
|
||||
|
||||
Hola, debes hacerlo como te indica MartinS, solo añadiendo, también puedes acceder al Item del ListBox de esta forma:
Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar. |
#11
|
|||
|
|||
listbox
muchas gracias martinS, y caro.... funciona a la perfeccion.. ahora estoy tratando de hacer: por ejemplo: si le asigno 5 materias a un grado y grabo,, pero se me olvido agregar otra.. como hago para que solo me grabe la nueva que voy a incluir. no se si me di a entender....
lo que estoy tratando es de crear un boton que me modifique la tabla utilizando el siguiente codigo:
entonces en el boton grabar comparo si la tabla esta en insert o en edit,,, pero el programa explota y dice que no se ha podido encontrar el hilo. lo que quiero es que la que ya estan grabadas me las deje intacta y que solo grabe la nueva que se incluyo. como me pueden ayudar..gracias |
#12
|
|||
|
|||
Hola donpedro: Antes que nada no se que tipo de base de datos estas usando y mucho menos su estructura. Ahora bien, en algun lugar lei que ya estas cerca de finalizar tus estudios de informatica por lo tanto "solo expondre" la idea de lo que YO haria:
1.- Usaria una ventana similar a la carga de datos pero lo que deberias hacer es levantar del curso las materias y colocarlas en el listbox
2.- Hace las incorporaciones nuevas y van a ir agregandose al final del listbox2 3.- Grabar... Pero no tan facil Debes recorrer el listbox y fijarte cual es la que agregaste, si quieres puedes usar el metodo locate de modo que si lo encuentra pasa al siguiente elemento del listbox y si no lo graba.- Ahh! el locate puede dar un valor booleano, es decir puedes usarlo así:
Nuevamente: Estoy dando ideas a ciegas, No conozco ni la base ni la estructura y puede ser que tambien debas hacer muchas mas comprobaciones antes de guardar, por ejemplo si cambia las materias ya guardadas o le cambian el nombre, etc. etc... En definitiva y tal vez sea demasiado bruto pero hay que hacer muchas cosas en papel (Analisis, posibilidades, diagramas) antes de escribir el codigo, algo que seguramente tu ya lo sabes Bueno cualquier cosa estamos aquí. Saludos.- |
#13
|
||||
|
||||
Hola donpedro.
Si no entendí mal tu consulta, no sería una modificación, en realidad es agregar un nuevo dato que corresponde a determinado curso. En ListBox2 se van añadiendo las materias correspondientes al curso, por lo que antes de guardar el nuevo dato agregado, este deberá encontrarse en la última posición de este componente. Entonces creo que tendrías que hacer:
Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#14
|
|||
|
|||
muchas gracias martinS, pido excusa por no especificar la base de datos,, estoy utilizando mysql.....estare probando tu logica,,, luego compartire el resultado...
|
#15
|
|||
|
|||
Cita:
Saludos.- |
#16
|
|||
|
|||
Cita:
|
#17
|
|||
|
|||
hola de nuevo, estoy mejorando la pantalla y estoy frenado en algo: en la nueva pantalla estoy utilizando un dbgrid y un listbox (con base de datos mysql). estoy pasando registros de un dbgrid al listbox como se muestra en la siguiente figura.
lo que quiero es que cuando mueva una materia del dbgrid al listbox dicha materia se quite del dbgrid. me explico,, si por ejemplo muevo la materia matematica que se compare si algun registro del dbgrid es igual a los del listbox y si es asi que lo quite del dbgrid para asi poder ver las materias que no he agregado... espero que hallan entendido. trate con el siguiente codigo el cual esta en el mismo boton donde muevo los items.
cuando ejecuto ese codigo y selecciono por ejemplo matematica y lo paso al listbox dicha materia se quita del dbgrid, pero si elijo otra por ejemplo lengua española se me agrega al listbox se me borra del dbgrid pero matematica vuelve y aparece en el dbgrid.. espero que me hallan entendido,, espero respuesta y muchas gracias de antemano... |
#18
|
|||
|
|||
Hola donpedro: creo que te entendi sobre lo que apuntas pero vas a tener varios inconvenientes a la hora de hacer el pase de materias.-
En primer lugar la consulta pareciera que funcionara pero para que pueda ir quitando las materias del dbgrid debes ir agregando condiciones al where del sql y ciertamente se puede volver bastante engorroso. Calcula que si hace... (Como se dice en Argentina "A la criolla") 1 listar todas las materias Seleccionaste despues matematica, entonces 2 listar todas las materias, salvo matematicas (anda joya) despues seleccionas geografia, entonces 3 listar todas las materias, salvo matematicas y salvo geografia y asi sucesivamente vas a tener una consulta bastante grande y que no seria de gran utilidad; mas aun si el cliente decide eliminar una de ellas de las ya asignadas entonces deberias "ubicar" cual es la condicion afectada en el SQL Creo que debes volcar todas las materias a un listbox y no a un dbgrid y de ahi hacer el pase para el otro listbox como ya has expuesto en mensajes anteriores Otra idea podria ser que al momento de dar de alta nuevas materias primero pongas las materias del curso en el listbox2 que ya habias guardado y despues a hace una consulta de las materias generales e incorporalas al listbox1 pero solo las que no aparecen en el listbox2 asi:
El mismo tipo de comprobacion lo puedes hacer cuando pasas las materias de un lado al otro si no borras el origen, si no, primero has el pase
y despues borras el origen
Dicho esto creo que es la mejor manera de manejar el pase de materias (Puede no ser la unica forma).- Ah!! Usa para otra pregunta (como la que hiciste) un nuevo hilo así no confundimos las respuestas y tus dudas saltan al primer lugar de la lista de post aumentando las posibilidades de que alguien que la tenga mas clara (que por cierto hay muchos) conteste y te de una mano. Saludos.- |
#19
|
|||
|
|||
pense, que si voy a tratar del mismo tema, no podria crear un nuevo hilo......gracias de todos modos voy a cambiar el dbgrid por un listbox......
|
#20
|
||||
|
||||
Cita:
Si es algo diferente, distinto, entonces hilo nuevo. |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Cargar campos de la tabla en un listbox | sancarlos | SQL | 4 | 03-07-2008 19:10:59 |
agregar y/o eliminar items de un listbox a partir de otro listbox | Goyo | PHP | 2 | 27-09-2007 16:46:30 |
ListBox | Tala | OOP | 3 | 21-06-2006 16:31:46 |
Copiar los campos de una tabla a un ListBox | JuanErasmo | C++ Builder | 1 | 22-09-2005 02:13:18 |
ListBox | neon | OOP | 2 | 09-08-2004 11:15:27 |
|