SyntaxError: недопустимый синтаксис для модуля yt - PullRequest
0 голосов
/ 11 июля 2020

Я пытаюсь понять, в чем проблема, но я не могу полностью понять, почему я получаю эти ошибки, тем более что в этой ошибке указано, что я считаю ложным срабатыванием. Я знаю, что это как-то связано со строкой: for file in glob.glob('puredef_hdf5_chk_000000'), но я не уверен, что это может быть.

import yt
import glob

for file in glob.glob('puredef_hdf5_chk_000000')
ds=yt.load(file)

#########################################
slc= yt.ProjectionPlot(ds,'theta','density')
slc= yt.SlicePlot(0.25,p_size=15.0,col="Pink")
slc.set_cmap('density',('Blues'))
slc.annotate_particles(0.25,p_size=12.0,col='Red')
slc.save('tr')
#########################################
# This
#slc = yt.SlicePlot(ds,"theta", ["density"])
#slc.set_cmap("density","Blues")
#slc.annotate_particles(0.25, p_size=12.0, col="Red")
#slc.save('tr')
##########################################
p = yt.ProjectionPlot(ds,"theta","density",center='m',width=(10, 'Mpc'))
p.annotate_particles((10,'Mpc'))
p.save('tr')
############################################################
#p = yt.ParticlePlot(ds, 'particle_position_x', 'particle_position_y', 'particle_dens')
#or
#p = yt.ParticlePlot(ds, 'particle_position_cylindrical_radius', 'particle_position_cylindrical_theta', 'particle_dens')
# Above is for axi-symmetric
#p.set_ylim(-2.5e10,3.5e10)
#p.set_xlim(1e10,3.5e10)
#p.set_zlim('particle_dens', 1e1, 1e13)    #fixed the density axis
#p.save()
######################################################
#ad = ds.all_data()
#print(ad['particle_position_y'])
######################################################

runfile('C:/Users/rocke/AppData/Local/Packages/CanonicalGroupLimited.UbuntuonWindows_79rhkp1fndgsc/LocalState/rootfs/home/richard/new 1.py', wdir='C:/Users/rocke/AppData/Local/Packages/CanonicalGroupLimited.UbuntuonWindows_79rhkp1fndgsc/LocalState/rootfs/home/richard')
  File "C:\Users\rocke\AppData\Local\Packages\CanonicalGroupLimited.UbuntuonWindows_79rhkp1fndgsc\LocalState\rootfs\home\richard\new 1.py", line 4
    for file in glob.glob('puredef_hdf5_chk_000000')
                                                    ^
SyntaxError: invalid syntax

Ответы [ 2 ]

0 голосов
/ 11 июля 2020
yt : [WARNING  ] 2020-07-11 16:27:32,912 Extending theta dimension to 2PI + left edge.
yt : [INFO     ] 2020-07-11 16:27:32,927 Parameters: current_time              = 0.0
yt : [INFO     ] 2020-07-11 16:27:32,928 Parameters: domain_dimensions         = [2 2 0]
yt : [INFO     ] 2020-07-11 16:27:32,929 Parameters: domain_left_edge          = [ 0.0000e+00 -6.5536e+09  0.0000e+00]
yt : [INFO     ] 2020-07-11 16:27:32,931 Parameters: domain_right_edge         = [6.55360000e+09 6.55360000e+09 6.28318531e+00]
yt : [INFO     ] 2020-07-11 16:27:32,932 Parameters: cosmological_simulation   = 0.0
yt : [INFO     ] 2020-07-11 16:27:32,939 Allocating for 8.800e+01 particles (index particle type 'all')
yt : [INFO     ] 2020-07-11 16:27:32,941 Identified 9.000e+00 octs
Traceback (most recent call last):

  File "C:\Users\rocke\AppData\Local\Packages\CanonicalGroupLimited.UbuntuonWindows_79rhkp1fndgsc\LocalState\rootfs\home\richard\new 1.py", line 8, in <module>
    slc= yt.ProjectionPlot(ds,'theta','density')

  File "C:\Users\rocke\anaconda3\lib\site-packages\yt\visualization\plot_window.py", line 1464, in __init__
    validate_mesh_fields(test_data_source, fields)

  File "C:\Users\rocke\anaconda3\lib\site-packages\yt\visualization\plot_window.py", line 132, in validate_mesh_fields
    canonical_fields = data_source._determine_fields(fields)

  File "C:\Users\rocke\anaconda3\lib\site-packages\yt\data_objects\data_containers.py", line 1165, in _determine_fields
    finfo = self.ds._get_field_info("unknown", fname)

  File "C:\Users\rocke\anaconda3\lib\site-packages\yt\data_objects\static_output.py", line 798, in _get_field_info
    raise YTFieldNotFound((ftype, fname), self)

YTFieldNotFound: Could not find field '('all', 'density')' in puredef_hdf5_chk_000000.

Кажется, я получаю новые ошибки, делая это по-вашему, но сейчас он читает мои файлы данных. Раньше я не видел этой ошибки, так как она характерна только для модуля yt.

0 голосов
/ 11 июля 2020

Вам не хватает :

for file in glob.glob('placeholder'): # Make sure you add the ':'
    ... # And indent

Кроме того, содержимое внутри for l oop должно иметь отступ на одну вкладку

Попробуйте следующее:

import yt
import glob

for file in glob.glob('puredef_hdf5_chk_000000')
    ds=yt.load(file)
    
    #########################################
    slc= yt.ProjectionPlot(ds,'theta','density')
    slc= yt.SlicePlot(0.25,p_size=15.0,col="Pink")
    slc.set_cmap('density',('Blues'))
    slc.annotate_particles(0.25,p_size=12.0,col='Red')
    slc.save('tr')
    #########################################
    # This
    #slc = yt.SlicePlot(ds,"theta", ["density"])
    #slc.set_cmap("density","Blues")
    #slc.annotate_particles(0.25, p_size=12.0, col="Red")
    #slc.save('tr')
    ##########################################
    p = yt.ProjectionPlot(ds,"theta","density",center='m',width=(10, 'Mpc'))
    p.annotate_particles((10,'Mpc'))
    p.save('tr')
    ############################################################
    #p = yt.ParticlePlot(ds, 'particle_position_x', 'particle_position_y', 'particle_dens')
    #or
    #p = yt.ParticlePlot(ds, 'particle_position_cylindrical_radius', 'particle_position_cylindrical_theta', 'particle_dens')
    # Above is for axi-symmetric
    #p.set_ylim(-2.5e10,3.5e10)
    #p.set_xlim(1e10,3.5e10)
    #p.set_zlim('particle_dens', 1e1, 1e13)    #fixed the density axis
    #p.save()
    ######################################################
    #ad = ds.all_data()
    #print(ad['particle_position_y'])
    ######################################################
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...