remove temp file, IAEANuclearData.py is OK, but have problem to have 2 Plot Window
This commit is contained in:
parent
b0d329164a
commit
3eaaf071e7
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -7,3 +7,4 @@ Cleopatra/Isotope
|
||||||
Cleopatra/PlotTGraphTObjArray
|
Cleopatra/PlotTGraphTObjArray
|
||||||
|
|
||||||
__pycache__
|
__pycache__
|
||||||
|
IAEA_NuclearData.csv
|
|
@ -10,12 +10,14 @@ mp = 938.27208816 # +- 29
|
||||||
mn = 939.56542052 # +- 54
|
mn = 939.56542052 # +- 54
|
||||||
ma = 3727.37915
|
ma = 3727.37915
|
||||||
|
|
||||||
class Isotope:
|
class IsotopeClass:
|
||||||
def __int__(self):
|
def __init__(self):
|
||||||
|
|
||||||
self.livechart = "https://nds.iaea.org/relnsd/v0/data?"
|
self.livechart = "https://nds.iaea.org/relnsd/v0/data?"
|
||||||
self.data = None
|
self.data = None
|
||||||
|
|
||||||
|
self.DownloadData()
|
||||||
|
|
||||||
|
def DownloadData(self):
|
||||||
# Read the saved CSV file back into a DataFrame
|
# Read the saved CSV file back into a DataFrame
|
||||||
try :
|
try :
|
||||||
self.data = pd.read_csv('IAEA_NuclearData.csv')
|
self.data = pd.read_csv('IAEA_NuclearData.csv')
|
||||||
|
@ -163,7 +165,7 @@ class Isotope:
|
||||||
print(" Sa: %9.2f MeV" % self.GetSa(ASym))
|
print(" Sa: %9.2f MeV" % self.GetSa(ASym))
|
||||||
print("=============================")
|
print("=============================")
|
||||||
|
|
||||||
def PrintIsoWeb(self, ASym : str):
|
def PrintIsoHTML(self, ASym : str):
|
||||||
[A, Z] = self.GetAZ(ASym)
|
[A, Z] = self.GetAZ(ASym)
|
||||||
print("<br>========================= ", ASym)
|
print("<br>========================= ", ASym)
|
||||||
print("<br>A : %d, Z : %d, N : %d" % (A, Z, A-Z))
|
print("<br>A : %d, Z : %d, N : %d" % (A, Z, A-Z))
|
||||||
|
|
|
@ -4,6 +4,7 @@ import os
|
||||||
import platform
|
import platform
|
||||||
import subprocess
|
import subprocess
|
||||||
import sys
|
import sys
|
||||||
|
import time
|
||||||
from functools import partial
|
from functools import partial
|
||||||
from PyQt6.QtWidgets import (
|
from PyQt6.QtWidgets import (
|
||||||
QApplication, QMainWindow, QGridLayout, QPushButton,
|
QApplication, QMainWindow, QGridLayout, QPushButton,
|
||||||
|
@ -41,6 +42,7 @@ class PlotWindow(QWidget):
|
||||||
self.showMarker_checkBox = QCheckBox("Show Markers")
|
self.showMarker_checkBox = QCheckBox("Show Markers")
|
||||||
self.showMarker_checkBox.stateChanged.connect(self.plot_plotly_graph)
|
self.showMarker_checkBox.stateChanged.connect(self.plot_plotly_graph)
|
||||||
|
|
||||||
|
self.html_file = None
|
||||||
self.web_view = QWebEngineView()
|
self.web_view = QWebEngineView()
|
||||||
|
|
||||||
layout = QGridLayout(self)
|
layout = QGridLayout(self)
|
||||||
|
@ -83,6 +85,10 @@ class PlotWindow(QWidget):
|
||||||
# print(self.headers)
|
# print(self.headers)
|
||||||
|
|
||||||
def plot_plotly_graph(self):
|
def plot_plotly_graph(self):
|
||||||
|
|
||||||
|
if self.html_file and os.path.exists(self.html_file):
|
||||||
|
os.remove(self.html_file)
|
||||||
|
|
||||||
# Create a Plotly figure
|
# Create a Plotly figure
|
||||||
fig = go.Figure()
|
fig = go.Figure()
|
||||||
|
|
||||||
|
@ -145,13 +151,16 @@ class PlotWindow(QWidget):
|
||||||
)
|
)
|
||||||
|
|
||||||
# Save the plot as an HTML file in a temporary location
|
# Save the plot as an HTML file in a temporary location
|
||||||
with tempfile.NamedTemporaryFile(delete=False, suffix=".html") as tmp_file:
|
timestamp = int(time.time() * 1000) # Unique timestamp in milliseconds
|
||||||
fig.write_html(tmp_file.name)
|
html_file = f"/tmp/plotwindow_{timestamp}.html"
|
||||||
html_file = tmp_file.name
|
fig.write_html(html_file)
|
||||||
|
self.html_file = html_file # Store for cleanup
|
||||||
# Load the HTML file in QWebEngineView
|
|
||||||
self.web_view.setUrl(QUrl.fromLocalFile(html_file))
|
self.web_view.setUrl(QUrl.fromLocalFile(html_file))
|
||||||
|
|
||||||
|
def __del__(self):
|
||||||
|
if os.path.exists(self.html_file):
|
||||||
|
os.remove(self.html_file)
|
||||||
|
|
||||||
################################################## MainWindow
|
################################################## MainWindow
|
||||||
class MyWindow(QMainWindow):
|
class MyWindow(QMainWindow):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
|
@ -315,20 +324,6 @@ class MyWindow(QMainWindow):
|
||||||
def file_exists(self,file_path):
|
def file_exists(self,file_path):
|
||||||
return os.path.exists(file_path) and os.path.isfile(file_path)
|
return os.path.exists(file_path) and os.path.isfile(file_path)
|
||||||
|
|
||||||
def A_file_changed_after_B_file(self, file_a, file_b):
|
|
||||||
try:
|
|
||||||
modified_time_a = os.path.getmtime(file_a)
|
|
||||||
modified_time_b = os.path.getmtime(file_b)
|
|
||||||
|
|
||||||
# Compare the modification times
|
|
||||||
return modified_time_a > modified_time_b
|
|
||||||
except FileNotFoundError as e:
|
|
||||||
print(f"Error: {e}")
|
|
||||||
return False
|
|
||||||
except Exception as e:
|
|
||||||
print(f"An error occurred: {e}")
|
|
||||||
return False
|
|
||||||
|
|
||||||
def CalDWBA(self):
|
def CalDWBA(self):
|
||||||
|
|
||||||
self.SaveFile()
|
self.SaveFile()
|
||||||
|
@ -367,10 +362,7 @@ class MyWindow(QMainWindow):
|
||||||
# self.BashCommand("../Cleopatra/ExtractXSec " + self.DWBAFileName + ".out " + option)
|
# self.BashCommand("../Cleopatra/ExtractXSec " + self.DWBAFileName + ".out " + option)
|
||||||
|
|
||||||
if self.chkPlot.isChecked() and self.file_exists(self.DWBAFileName + ".Xsec.txt") :
|
if self.chkPlot.isChecked() and self.file_exists(self.DWBAFileName + ".Xsec.txt") :
|
||||||
if self.A_file_changed_after_B_file(self.DWBAFileName + ".Xsec.txt", self.DWBAFileName + ".out") :
|
|
||||||
self.open_plot_window()
|
self.open_plot_window()
|
||||||
else:
|
|
||||||
self.leStatus.setText( self.DWBAFileName + ".Xsec.txt is not newer than " + self.DWBAFileName + ".out")
|
|
||||||
|
|
||||||
def open_plot_window(self):
|
def open_plot_window(self):
|
||||||
if self.plot_window is None :
|
if self.plot_window is None :
|
||||||
|
@ -385,6 +377,7 @@ class MyWindow(QMainWindow):
|
||||||
def closeEvent(self, event):
|
def closeEvent(self, event):
|
||||||
if self.plot_window:
|
if self.plot_window:
|
||||||
self.plot_window.close() # Close the PlotWindow when MainWindow closes
|
self.plot_window.close() # Close the PlotWindow when MainWindow closes
|
||||||
|
self.plot_window.__del__()
|
||||||
event.accept() # Accept the event to proceed with closing the main window
|
event.accept() # Accept the event to proceed with closing the main window
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,11 @@
|
||||||
#!/usr/bin/python3
|
#!/usr/bin/python3
|
||||||
|
|
||||||
from IAEANuclearData import Isotope
|
from IAEANuclearData import IsotopeClass
|
||||||
|
|
||||||
iso = Isotope()
|
iso = IsotopeClass()
|
||||||
|
|
||||||
iso.PrintIso('16O')
|
iso.PrintIso('16O')
|
||||||
|
|
||||||
|
pd = iso.GetExList('16O', 10)
|
||||||
|
|
||||||
|
print(pd)
|
Loading…
Reference in New Issue
Block a user