## Licensed to the Apache Software Foundation (ASF) under one or more# contributor license agreements. See the NOTICE file distributed with# this work for additional information regarding copyright ownership.# The ASF licenses this file to You under the Apache License, Version 2.0# (the "License"); you may not use this file except in compliance with# the License. You may obtain a copy of the License at## http://www.apache.org/licenses/LICENSE-2.0## Unless required by applicable law or agreed to in writing, software# distributed under the License is distributed on an "AS IS" BASIS,# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.# See the License for the specific language governing permissions and# limitations under the License.#importos__all__=["SparkFiles"]fromtypingimportcast,ClassVar,Optional,TYPE_CHECKINGifTYPE_CHECKING:frompysparkimportSparkContext
[docs]classSparkFiles:""" Resolves paths to files added through :meth:`SparkContext.addFile`. SparkFiles contains only classmethods; users should not create SparkFiles instances. """_root_directory:ClassVar[Optional[str]]=None_is_running_on_worker:ClassVar[bool]=False_sc:ClassVar[Optional["SparkContext"]]=Nonedef__init__(self)->None:raiseNotImplementedError("Do not construct SparkFiles objects")
[docs]@classmethoddefget(cls,filename:str)->str:""" Get the absolute path of a file added through :meth:`SparkContext.addFile`. """path=os.path.join(SparkFiles.getRootDirectory(),filename)returnos.path.abspath(path)
[docs]@classmethoddefgetRootDirectory(cls)->str:""" Get the root directory that contains files added through :meth:`SparkContext.addFile`. """ifcls._is_running_on_worker:returncast(str,cls._root_directory)else:# This will have to change if we support multiple SparkContexts:assertcls._scisnotNoneassertcls._sc._jvmisnotNonereturncls._sc._jvm.org.apache.spark.SparkFiles.getRootDirectory()