16. marts 2016 - 10:01 Der er 1 løsning

Skriv i excel ark med epplus

Hej folkens.

Jeg sidder og er ved at lave et lille program der kan lave en alarmliste til en Siemens PLC. Det betyder at for hver komponent jeg har i mit projekt, skal jeg oprette mellem 2 og 5 alarm linjer i et excel-ark. Fx skal en motor generere Følgende alarmer:
1    Error    Trip        0    1A01A-B01M01.status    0                    0    0    POS 1A01A-B01M01 - SSW - -
2    Error    Alarm        0    1A01A-B01M01.status    1                    0    0    POS 1A01A-B01M01 - TH - -
3    Error    Alarm        0    1A01A-B01M01.status    2                    0    0    POS 1A01A-B01M01 - PIC - -
4    Error    Alarm        0    1A01A-B01M01.status    3                    0    0    POS 1A01A-B01M01 - SSW - -

for at lave det, ser min kode således ud:


foreach (HIComponent motor in MotorList)
                {
                    ws.Cells[i, 1].Value = i;
                    ws.Cells[i, 2].Value = "Error";
                    ws.Cells[i, 3].Value = "Trip";
                    ws.Cells[i, 5].Value = 0;
                    ws.Cells[i, 6].Value = motor.Tag + ".status";
                    ws.Cells[i, 7].Value = 0;
                    ws.Cells[i, 12].Value = 0;
                    ws.Cells[i, 13].Value = 0;
                    ws.Cells[i, 14].Value = "POS " + motor.Tag + " - SSW - " + motor.Desc;
                    i++;
                    ws.Cells[i, 1].Value = i;
                    ws.Cells[i, 2].Value = "Error";
                    ws.Cells[i, 3].Value = "Alarm";
                    ws.Cells[i, 5].Value = 0;
                    ws.Cells[i, 6].Value = motor.Tag + ".status";
                    ws.Cells[i, 7].Value = 1;
                    ws.Cells[i, 12].Value = 0;
                    ws.Cells[i, 13].Value = 0;
                    ws.Cells[i, 14].Value = "POS " + motor.Tag + " - TH - " + motor.Desc;
                    i++;
                    ws.Cells[i, 1].Value = i;
                    ws.Cells[i, 2].Value = "Error";
                    ws.Cells[i, 3].Value = "Alarm";
                    ws.Cells[i, 5].Value = 0;
                    ws.Cells[i, 6].Value = motor.Tag + ".status";
                    ws.Cells[i, 7].Value = 2;
                    ws.Cells[i, 12].Value = 0;
                    ws.Cells[i, 13].Value = 0;
                    ws.Cells[i, 14].Value = "POS " + motor.Tag + " - PIC - " + motor.Desc;
                    i++;
                    ws.Cells[i, 1].Value = i;
                    ws.Cells[i, 2].Value = "Error";
                    ws.Cells[i, 3].Value = "Alarm";
                    ws.Cells[i, 5].Value = 0;
                    ws.Cells[i, 6].Value = motor.Tag + ".status";
                    ws.Cells[i, 7].Value = 3;
                    ws.Cells[i, 12].Value = 0;
                    ws.Cells[i, 13].Value = 0;
                    ws.Cells[i, 14].Value = "POS " + motor.Tag + " - SSW - " + motor.Desc;
                    i++;
                }


Kan dette ikke gøres smartere?

hvis i undre jer, så indeholder motor.desc pt kun en "-".
31. marts 2016 - 07:15 #1
Ja, nu skal i da ikke råbe i munden på hinanden allesammen :) Jeg lukker den igen og lader den ligge for nu :)
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester