Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Polestar 3 Performance, test drive: comodità e potenza possono convivere
Polestar 3 Performance, test drive: comodità e potenza possono convivere
Abbiamo passato diversi giorni alla guida di Polestar 3, usata in tutti i contesti. Come auto di tutti i giorni è comodissima, ma se si libera tutta la potenza è stupefacente
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
In occasione del proprio Architecture Deep Dive 2025 Qualcomm ha mostrato in dettaglio l'architettura della propria prossima generazione di SoC destinati ai notebook Windows for ARM di prossima generazione. Snapdragon X2 Elite si candida, con sistemi in commercio nella prima metà del 2026, a portare nuove soluzioni nel mondo dei notebook sottili con grande autonomia
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
DJI Mini 5 Pro porta nella serie Mini il primo sensore CMOS da 1 pollice, unendo qualità d'immagine professionale alla portabilità estrema tipica di tutti i prodotti della famiglia. È un drone C0, quindi in un peso estremamente contenuto e che non richiede patentino, propone un gimbal rotabile a 225 gradi, rilevamento ostacoli anche notturno e autonomia fino a 36 minuti. Caratteristiche che rendono il nuovo drone un riferimento per creator e appassionati
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 23-09-2004, 15:34   #1
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
python, py2exe e COM

Ho sviluppato un programmino in python che usa excel tramite COM. Ora vorrei farne un eseguibile con py2exe ma la generazione mi fallisce con il messaggio
The following modules appear to be missing
['pythoncom']


Ho anche cercato su google ma non ho trovato una soluzione... qualche idea ?
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 23-09-2004, 17:50   #2
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
uhm....

mi sembra semplice come linguaggio o sbaglio ?


ho letto qua: http://programmazione.html.it/python/python_02.htm

e se mi dai qualche dritta mollo quel cavolo di visual basic

sto scrivendo pure io codice per manipolare fogli di excel, questo linguaggio è ideale ?

Ultima modifica di misterx : 23-09-2004 alle 18:01.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 23-09-2004, 21:26   #3
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Quote:
Originariamente inviato da misterx
e se mi dai qualche dritta mollo quel cavolo di visual basic
Eccomi qua, subito pronto

Quote:
sto scrivendo pure io codice per manipolare fogli di excel, questo linguaggio è ideale ?
Dipende... se il codice che scrivi deve essere richiamato da bottoni o altre macro di Excel, ho pausa che VBA sia l'unica soluzione praticabile.
Se pero' come me il foglio excel lo lavori "dall'esterno, allora python va benissimo.
Ad esempio in ditta lo uso per generarmi i files delle connessioni Terminal Server a partire dall'anagrafica dei clienti presente su di un foglio excel. U

Usare excel o word da python e' molto semplice, tanto quanto con Visual Basic (ma col vantaggio che python e' un linguaggio molto piu' flessibile).

Ad esempio (vado a memoria, essendo sotto linux al momento non lo posso testare )
Codice:
def generate_rdp( client , address ):
  f = file(r'c:\' + client + '.rdp' , 'w' )
  f.write( "blah blah blah" )
  f.close()

from win32com.clients import Dispatch

excel = Dispatch("Excel.Application")

wb = excel.Workbooks.Open(r'c:\prova.xls')
sheet = wb.Sheets[0]

for row in range(0,100):
  client = sheet.Cell(row,0)
  addr = sheet.Cell(row,1)
  generate_rdp(client,addr)

# eccetera
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 23-09-2004, 22:09   #4
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
visto così mi ricorda un misto di C e visual basic

ho idea che faccia al caso mio in quanto devo prelevare dati da fogli di excel e convertirli in HTML

c'è anche la possibilità di selezionare il foglio della cartella che hai aperto ?
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 23-09-2004, 23:11   #5
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Quote:
Originariamente inviato da misterx
visto così mi ricorda un misto di C e visual basic

ho idea che faccia al caso mio in quanto devo prelevare dati da fogli di excel e convertirli in HTML
Direi proprio di si' allora ! tra l'altro python mi sembra molto adatto per questi tipi di lavori


Quote:
c'è anche la possibilità di selezionare il foglio della cartella che hai aperto ?

Ti ho pure fatto l'esempio apposta :P
Codice:
...
sheet = wb.Sheets[0]
...
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2004, 08:51   #6
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
cominciamo proprio bene

ImportError: No module named win32com.client
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2004, 09:09   #7
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
fatto, mancava il solito pezzo = modulo = estenzione = ....
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2004, 09:44   #8
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Quote:
Originariamente inviato da misterx
fatto, mancava il solito pezzo = modulo = estenzione = ....
Me ne ero dimenticato... si', win32com e' un'estenzione di python; se pero' scarichi quello fornito da ActiveState trovi gia' tutto compreso.
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2004, 09:52   #9
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
ora provo a creare l'eseguibile, sperem....
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2004, 10:26   #10
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
ma anzichè in bytecode, non si può creare un eseguibile stand-alone?
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2004, 11:03   #11
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Piu' o meno.
Esiste un programma chiamato py2exe che prende ti prepara un programma in formato exe. In realta penso che prepari un mini run-time che va ad eseguire il bytecode
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2004, 11:09   #12
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
allora è una fregatura

se devi distribuire un programma devi far installare loro una sorta di "python machine" ?
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2004, 13:23   #13
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Quote:
Originariamente inviato da misterx
allora è una fregatura

se devi distribuire un programma devi far installare loro una sorta di "python machine" ?
No. Ti viene generato una cartella con un file exe (il tuo programma), uno zip (il bytecode) e una dll (il runtime del python), piu' le eventuali librerie aggiuntive usate
Copi la cartella e sei a cavallo.
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2004, 15:18   #14
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
a me non crea nulla
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2004, 01:45   #15
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Quote:
Originariamente inviato da misterx
a me non crea nulla
devi creare un file a parte per la generazione dell'eseguibile
Se ad esempio hai un file myscript.py di cui vuoi generare un eseguibile, crei un altro file python (setup.py) con il seguente contenuto

Codice:
# setup.py
from distutils.core import setup
import py2exe
      
setup(console=["myscript.py"])
lanciando python setup.py py2exe ti verra' generata la cartella con l'eseguibile. In alternativa a console=... puoi usare windows (per una applicazione con finestre), comserver (per un server com) o service (per creare un servizio di windows). Piu' o meno ovviamente... per una spiegazione piu' precisa controlla la documentazione
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2004, 08:40   #16
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
fatto marco,

mi mancava una dll
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2004, 17:52   #17
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
OT

risolto il tuo problema iniziale ?

sai come si fa a selezionare un foglio dopo che hai aperto una cartella di lavoro ?

ho provato con:

.....

wb = excel.Workbooks.Open(r'c:\prova.xls')
wb.WorkSheets(2).Activate

....

ma non funziona
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2004, 20:43   #18
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Quote:
Originariamente inviato da misterx
wb = excel.Workbooks.Open(r'c:\prova.xls')
wb.WorkSheets(2).Activate

....

ma non funziona
Qeute cose le guardo solo al lavoro (e sul lavoro non accedo al forum se non durante la pausa pranzo), quindi non so darti la risposta precisa. Mi sembra che la sintassi corretta debba essere wb.WorkSheets.Item(2).Activate.
Se fai
wb = excel.Workbooks.Open(r'c:\prova.xls')
print dir(wb.WorkSheets)

dovresti ottenere sulla console la lista di tutti i metodi di WorkSheets (ignora pure quelli che iniziano con '_' ).
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2004, 21:46   #19
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
Quote:
Originariamente inviato da /\/\@®¢Ø

print dir(wb.WorkSheets)

dovresti ottenere sulla console la lista di tutti i metodi di WorkSheets (ignora pure quelli che iniziano con '_' ).

questa è un'informazione che vale oro

io a casa invece non ho installato Excel, siamo pari

grazie
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 28-09-2004, 08:12   #20
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
Quote:
Originariamente inviato da misterx
OT

risolto il tuo problema iniziale ?

sai come si fa a selezionare un foglio dopo che hai aperto una cartella di lavoro ?

ho provato con:

.....

wb = excel.Workbooks.Open(r'c:\prova.xls')
wb.WorkSheets(2).Activate

....

ma non funziona
mancavano solo le () di chiusura


wb.WorkSheets(2).Activate() = wb.WorkSheets(2).Select()
misterx è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice Recensione DJI Mini 5 Pro: il drone C0 ultra-leg...
ASUS Expertbook PM3: il notebook robusto per le aziende ASUS Expertbook PM3: il notebook robusto per le ...
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Ricarica delle auto elettriche in 3 minu...
Lucid presenta Gravity Touring, il SUV e...
Meta è stata condannata in Spagna...
Chat di gruppo su ChatGPT: al via la fas...
Ubisoft, dietro la trimestrale rimandata...
Gli sviluppatori di Genshin Impact hanno...
Poltronesofà colpita da ransomwar...
FSD e Autopilot: Tesla aggiorna i dati c...
Conclusa la campagna di osservazione del...
Il punto della situazione sulle offerte ...
Windows compie 40 anni, tra conquiste e ...
Black Friday Smartwatch: Amazfit, Apple,...
Operativo il primo Tesla Supercharger te...
Grok idolatra Elon Musk e lo considera s...
Il telescopio spaziale James Webb ha oss...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 14:46.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v